برمجة الفيجوال بيسك2008 


کتاب مترجم عن کتاب : 


Programming Visual Basic 2008 


بسم الله الرحمن الرحيم 
الحمد لله رب العالمين والصلاة والسلام على سيد المرسلين سيدنا محمد وآله وصحبه وسلم. 


هذا كتاب برمجة الفجيوال بيسك2008»وهو كتاب يركز كثيرآً على الجانب العملي بكل معنى الكلمة وقد حاولت فيه قدر الإمكان تسهيل استخدامه للقارئ 
العربي »مع العلم أن مشروع الكتاب مترابط من البداية إلى النهاية »والكتاب يحوي 25 فصل بحيث يغطي تقريبا معظم مواضيع البرمحة تحت الفيجوال 
بيسك2008»ولا بد من استخدامه أن يكون لديك دراية نوعا ما في البرمجة تحت الفيجوال بيسك لأنه لايبداً من البداية ولكن بإمكانك إذا واصلت القراءة 
المتسلسلة حتى ولو كنت مبتدءا أن تتعلم الكثير وربما توفق بمعرفة الكثير ولا أقول أنه ليس للمبتدئين ولكنه بشكل خاص للمحترفين. 


حاولت في هذا الكتاب»عمل مشروع الكتاب باللغة العربية ولكنني لم أوفق بترجمة كل شيء لضخامته وخاصة التعليقات على الكود وحيث أنها مكررة 
كثيرا فبإمكانك فهمها من خلال ما عملت على ترجمته.وكوني مترجم أكثر منه مبرمج»وكون الكتب التي تحتاج إلى ترجمة كثيرة»وحتى الآن ›استعين بالل 
في ترجمة كتاب آخر وأعمل به وقد ترجمة حوالي ستة فصول »هذا غير كتاب "حتى الاحتراف فيجوال بيسك2008" والذي لم أنهيه بعدءلأن كاتب آخر 
ربما یکون قد عمل كتاب كامل بخصوصه حتى ولو كان بخصوص الفيجو ال بيسك2005ءفرأيت أن من الواجب علي توفير كتاب آخرءفكان هذا الكتاب. 


عملت على تضمين قاعدة بيانات سكول سرفر الضرورية للمشروع مع مشروع الكتاب وطبعاءلن أنشر برامج جميع المشروع فما سأنشره هو المشروع 
بشكله النهائي »مع العلم أني قد عطلت بعض الميزات مثل التقارير وتستطيع تفعيلها والتعديل عليها »وبسبب انخفاض سرعة الانترنت عندنا والمشتاكل 
التي نعاني بها فيه»اختصرت النشر على المشروع بشكله الأخير. 


هذه محاولة على طريق تطور أمتنا »أرجو أن تستفيد منها الأمة .هذا الكتاب مجاني للجميع»وثمنه الدعاء لي بظهر الغيب. 


جميع الحقوق محفوظة للكاتب تيم باتريك»والمترجم ۸١76‏ وأرجوا أن لايستغله أحد.والحمد لله رب العالمين. 


الفصل الأول:كائنات الدوت نت mhm76‏ 


The .NET Object. كائنات الدوت نت‎ 

من أجل الفهم الكامل لتطوير البرمجيات في الدوت نت»يجب أن تفهم ما هي الكائنات.(إذا كنت على دراية بالبرمجة الموجهة بالكائنات ءبإمكانك الذهاب 
إلى المقطع التاليءولكن ستفقد بعض من المحتوى الهام).وحيث أن بعض من هذه المعلومات في هذا المقطع ستظهر في الفصل الثامن»يبقى من الهام شرح 
بعض من مفاهيم الدوت نت ¬ OBESE EEE‏ 
من وجهة نظر البرمجةءيقوم الكمبيوتر بعمل أربع مهام أساسية: 

> إنه يخزن البيانات هاج لفي المنطقة الخاصة بذاكرة الكمبيوتر. 

> إنه يدعم معالجة هذه البيانات هاه من خلال العمليات الأساسية المتضمنة الجمع ءالطرحءوالجبر المنطقي»ومعالجة المتغيرات النصية 

للنصوص. 
۷ انه يسمح للمستخدم من التفاعل مع البيانات وول المخزنة في الذاكرة. 
> إنه يوفر طريقة ما لجلب البيانات ههل وإدخالها بالإضافة إلى إخراجها من الذاكرةءمن خلال وسائل الإدخال والإخراج مثل لوحة 
المفاتيح(إدخال) والطابعات(وسائل إخراج)وكذلك وسائل التخزين المختلفة مثل السواقات. 

إن جوهر هذه المهام الأربعة هو البيانات وهاهه. يوجد الكمبيوتر لمعالجة البيانات» توفر أنظمة التشغيل حجر الأساس لهذه المهام .ولكنها تطبيقات برمجية 
تنشئ القدرة لهذه الميزات رiاااج‏ هطا-ءهںاهمf‏ لكي تعالج بيانات حقيقية اهم۲-هاهك ذات معنى للمستخدم. إن لغات البرمجة العالية المستوى 
programming languages‏ اeveا-High‏ هي الأدوات الأساسية المستخدمة لتطوير هذه التطبيقات» وتستخدم كل منها بعض الطرق العامة لجعل 
ميزات معالجة البيانات متاحة للمبرمج. 
بالعودة إلى الأيام الذهبية للبرمجة بلغة التجميع «assembly‏ و اذا علمت قسم عنونة الذاكرة memory address‏ لقطعة من البيانات»٬فبإمكانك‏ الوصول 
إليها ومعالجتها مباشرة. في الأيام الأولى للغة البيسك وفي أغلب لغات البرمجة(الإجر ائيةاهإu‏ لمعه م)الأخرىءكان الوصول للبيانات يتم من خلال 
المتغير اتوم/ط ههر . وبما أن اللغات قد تطورت في التعقيد والأهداف»وعليه فقد تطور عرضها للبيانات.فيما يخص لغة۴ 1|5 (اختصار ل اكا 
Processing‏ و Lots of |rritating Silly Parentheses!‏ )ءفإنه تتواجد أي قيمة للبيانات ضمن قائمة | أو مجموعة اء كبيرة من البيانات.لكن في 
لغات الدوت نت»فانه یتم عرض البيانات من خلال الكائنات object‏ . 
فالكائنات هي مجمو عة قيم البيانات ومصحوبة بالكود المصدري. بينما في لغات البيسك القديمةء كان كل عنصر من البيانات أكثر أو أقل استقلالية من 
خلال متغیره السترزري المخصص)» المرتبط بقيم البيانات في اللغات الكائنية التوجه(أو الموجهة بالكائناتءمووںوہه!ا 00۴ )التي يمكن تصنيفها إلى 
كائنات. وغالبا ما تتضمن تنفيذات الكائن كود مصدري مصمم لمعالجة قيم البيانات لذلك الكائن. 
تمثل الكائنات e‏ عام شيء ماء وغالبا ما يكون لهذا الشيء مثيل(نظير)في العالم الحقيقي لاه س-اهه»إما ماديا أو ظاهريا(معنويا). على سبيل المثال»من 
المحتمل أن يتضمن كودك كائن المنزل الذي له حقول ءل|ما؟ بيانات أو خصائص ها همهم للعنوان» كلون الدهان الخارجي » وعدد الناس القاطنين 
في المنزل. فالكود المصدري المساعد يمكنه أن يدير تلك البيانات: فطريقة ل١هط٤هم‏ الطلاء تغير قيمة اللون المستخدمة للدهان الخارجي. تدعى البيانات 
وعناصر الكود ضمن كائن ما بالأعضاء ۲s٥ط‏ 6 .وإن بعض الأعضاء مخفي داخل الكائن ويتم الوصول إليها فقط بالكود المصدري للكائن. الأعضاء 
الأخرى أكثر عمومية :حيث يمكن لأي كود في تطبيقك أن يستخدمها »وهي ليست مجرد مجموعة جزئية من كود تطبيق موجود داخل الكائن. اعتبر التلفاز 
ككائن ماء فالأعضاء العامة للتلفاز على العموم هي سهلة الاستخدام : زر الطاقة »جهاز التحكم ٬التحكم‏ بالصوت »وهكذا . وهذه المسالك التي من خلالها 
يتحكم المستخدم بقيم بيانات التلفاز (مخرجات الفيديو والايديو) .توجد أيضا أعضاء مخفية داخل التلفاز : بإمكانك استخدام هذه الأعضاء لتؤثر على الصورة 
وجودة الصوت ءعلى الرغم من أن هذا سيكون فكرة سيئة لأغلب المستخدمين .وبنفس الطريقة لايحتاج الكائن لكود خارجه للعبث بمكوناته الداخلية في 
ماعدا الأعضاء العامة . لاأهتم كيف يعمل التلفاز داخليا » طالما أنني أستطيع الحصول على الصورة والصوت الخارج منه باستخدام المتحكمات 
(الأدوات) التي تم عرضها(الطاقة › القناة » الصوت). 


تمثل المكونات العامة للكائن واجهته عع و/716/.فإذا ماأراد كود من خارج الكائن معالجة البيانات المنتمية لذلك الكائن» فإنه يستخدم أعضاء الواجهة. ليس 
عليه أن يفهم الأعضاء المخفية أو كيفية عملهاءوذلك جيد . وخاصة إذا تغيرت هذه الأعضاء الداخلية لأي سبب كان» من الممكن أن يحدث غالبا أكثر مما 
تعتقد رتل اكات في ار اة بات بقن الط رة رر قار اند كان باك ر اة رة ر حل ر ا راسا ا اا ا يلك 
أدوات تحكم عن بعد ويشغل حيز أقل ويحتوي على قنوات ووظائف أكثر ولكن الواجهة تقريبا نفسها). طالما أن الواجهة العامة بقيت تقريبا كما هي » فإن 
الكود الفعلي للكائن ونظام تخزين بيانات داخلية معروف أيضا بتنفيذ الكائن يمكن تغييره دون التأثير على كامل التطبيق. 


بالحقيقة إن الواجهة و التنفيذ لكائن تمثلان هيكله فقط »وهذه هي الأجزاء التي ينشئها المبرمج من خلال الكود المصدري . وحتى أنها توجد قبل أن ينصب 
ويترجم البرنامج على كمبيوتر المستخدم . في الحقيقة » في هذا المستوى » حتى أن الكائنات لا ثعرف بشكل حقيقي بالكائنات . في معظم اللغات (ومن 
ضمنها الفيجوال بيسك) » فإن الكلمة فة ووواع ند تشير إلى عملية تنفيذ واجهة كائن ما. حالما يتم تنصيب تطبيقك على الكمبيوتر وتشغيله › فإن الكود ينشئ 
نسخة ومعمه†وم| من الفئة ليخزن البيانات الفعلية في الذاكرة . هذه النسخ (الصور) هي الكائنات الحقيقية من تطوير البرمجة الموجهة بالكائنات 00۲. 
اعتماداً على طريقة كتابة كودك › > فربما يتم استخدام تنفيذ فئة وحيدة لإحداث واحدة أو حتى المئات من الكائنات في الذاكرة بنفس الوقت. 

في الدوت نت» تظهر جميع قيم كودك وبياناتك داخل الكائنات . وجميل جداً ان يکون کل شيء تراه في برنامج التنفيذ هو كائن ما :حيث أن نموذج 
ويندوز هو كائن ما : أداة صندوق القائمة ×0ط ءا التي على ذلك النموذج هي كائن ما : وبند مفرد في صندوق القائمة ذاك هو كائن ما. 


: 


يوجد هناك الكثير من أجزاء إطار عمل الدوت نت التي ما زالت قيد المناقشة . وتظهر هذه الأجزاء كثيرآً في توثيق الدوت نت »وكل منها لديه كلمة 
مركبة من ثلاثة حروف )A7( three-l e)6 2٥0۸۷"‏ › أو ما شابه ذلك . 


تقع لغة التنفيذ المشتر كة(C1R) ۸u 1e‏ eوuaوLan‏ مoرصصom‏ موقع القلب بالنسبة لإطار عمل الدوت نت » فكل شيء تعمله في برنامج الدوت 
نت تتم إدار تھ "a2۸29 ٥d‏ بوساطة لغة التنفيذ المشتركة C1۸‏ . عندما تنشئ متغيرآً ما » اشكر لغة التنفيذ المشتركة CR‏ ونظام إدارة بياناتها 


٣ح‎ 


الفصل الأول:كائنات الدوت نت mhm76‏ 


ementوaہهص.عندما‏ تعمل على حذف قطعة من البيانات » اشكر لغة التنفيذ المشتركة C1۸8‏ وكيف تدير مو2 التخلص من البيانات من خلال 
نظام تجميع النفايات التابع لها. هل لاحظت كم يتكرر ظهور الكلمة موةمهم" في تلك الجمل ؟ ولكن التعبير المناسب › هو ماذا تعمل لغة التنفيذ 
المشتركة . في الحقيقة » تدعى البرامج المكتوبة من أجل إطار عمل الدوت نت الكود المدار م0هء ۵١عوو/4””.‏ أي كود يحدث خارج سيطرة لغة التنفيذ 
المشتركة ٠‏ المتضمنة aكligٽ (ActiveX) COM‏ المستعملة من قبل تطبيقك الدوت نت › المعروف بالكود الغير مدر unmanaged code‏ . تشبه لغة 
التنفيذ المشتركة كثير! مطار لوس انجلوس الدولي . فالطائرات تصل و تغادر في كل دقيقة . السيارات بالآلاف تدخل وتغادر طريق الأوتوستراد و 
مركز المباني العامة . يتحرك الناس واللصوص باستمرار بين المحطات الرئيسية الثمانية والمحطة الدولية الضخمة . يوجد أحداث كثيرة » ولكن تتم إدارة 
الكثير منها. فالطائرات لا يمكنها الإقلاع أو الهبوط بدون موافقة على ضبط التحليق . تدير البوابات و نقاط الوصول الطرق و الكراجات العامة . بصدق › 
تدير وكالات 15۸ الجيدة طيران المسافرين و اللصوص داخل وخارج المناطق المأمونة للمحطات . تؤكد هياكل الإدارة والضبط في مكان ما في ×1۸ 
بشكل مرتب ومضمون طيران الناس بين طائراتهم ومدنهم من لوس انجلوس . وتؤكد هياكل الضبط والإدارة في لغة التنفيذ المشتركة CK1۸‏ بشكل مرتب 
ومضمون على تدفق البيانات بين كود الدوت نت وبقية الكمبيوتر أو الشبكة المتصلة .و من المحتمل أنك تود أن تعرف عن سر كيفية كون لغة التنفيذ 
المشتركة قادرة على معالجة البرامج المكتوبة في أي لغة من لغات الدوت نت › المتضمنة الفيجوال بيسك و سي شارب والفورتران . وهذه هي إرادة 
المتنافسين في الميكروسوفت . بالواقع إنهم يعرفونه بالفعل» لأنه لا يوجد سر.تحول كل لغات الدوت نت الممكنة (بمعنى تترجم) كودك المصدري إلى اللغة 
ميکر و سو فت الو سيطنع و2 ںو12 /ntermedia1e‏ اMicroso‏ )أو MS/£‏ » وبشكل عام اختصرت 1/) وهي اللغات المعروفة من قبل لغة التجميع 
ua9eوanا‏ yاbصهءءه‏ التي تبدو غير مفهومة . على سبيل المثال » يوجد هنا بعض الكود المصدري للفيجوال بيسك لتطبيق الكونسول الذي يطبع 
بشكل مبسط ”!اه۷ ,هاام“» من إجرائية الكود المسماة رأ" : 


Module Modulel 
CUS Main (J 
CORSOLeE. WE1 Ecele (Rell MOE LI) 
Console. Read () 
ERA SUS 
End Module 
وهو برنامج الدوت نت الكامل . عندما يحوله مترجم الفيجوال بيسك إلى لغة الميكروسوفت الوسيطة 8|1" › تبدو الإجرائية راج مشابهة لهذه (نوعا ما‎ 
معدلة لتتناسب مع هذه الصفحة)‎ 
.method public static void Main( ) cil managed 
1 
.entrypoint () 
CUS EOM insta Ce VOIS [MSCOELNON SVS ECEM 
SIATREeAdAEEEIOUEEe: CEO J) JD COT OC OO OO) 
//4 Code Siz LÛ (O) 
.maxstack (8) 
I OOOO LOSE E (UME LO, WOCLS Y) 
_ UOUOS: CAN 
OLE [MSCOE LL OMSEEM. COASOLE § EWE LEELAAE (EE EIDE) 
OOO: Ee 
MM md OE Met HOS Module: Main 
وهذا ما نعتبره فعلاً في الدوت نت . طالما أنك تستطيع أن تحصل على كودك داخل اللغة‎ › C18 نعم»إنه مبهم.ولكنه مناسب» تفهمه لغة التنفيذ المشتركة‎ 
الوسيطة | ءفان الدوت نت سوف تعالجه. يحدث مترجم الفيجوال بيسك تماما ليولد اللغة الوسيطة | من أجلك . و كذلك مترجمات لغة الدوت نت‎ 
الأخرى» المتضمنة سى شارب » واللغة الوسيطة | الهدف. حتى أنه يمكنك أيضا أن تكتب كود اللغة الوسيطة | الخاص بك» لكن من المحتمل أنك تقرأً‎ 
. الكتاب الخطأً من أجل ذلك . فقط طمئن نفسك › سيكون هذا الجزء الأخير من اللغة الوسيطة | التى تراها فى هذا الكتاب‎ 


Hf HH 


اللغات التي تدعي دعم الدوت نت لا يمكنها فقط أن تقول ذلك لأي سبب قديم . في الواقع عليها أن تكون منسجمة مع الدوت نت و أعمالها. و قد تم عمل 

ذلك من خلال توصيف اللغة المشتركة (58-ا٣) Language Specification‏ 070صص . يعرف توصيف اللغة المشتركة C158‏ أصغر مجموعة 
من الميزات التي يجب على اللغة أن تنجزها قبل أن تعتبر خاضعة للدوت نت › أو بدقة »خاضعة لتو صيف اللغة المشتركة "iaزرمcom CLS-‏ 

يمكن أن تذهب اللغة إلى ما وراء الحد الأصغر إذا أر لدت ذلك ر اشن لفرت نت العهة من ال اك اة فوق ميزات اللغة المحددة اتی يكن 

أن تبنى . من الممكن أن لا تكون اللغة التي تنفذ الحد الأصغر فقط لتوصيف اللغة المشتركة المحددة قادرة على التفاعل الكامل بين مكونات اللغات التي 

تجاوزت توصيف الحد الأصغر. الفيجوال بيسك هي » بالطبع » تابعة لتوصيف اللغة المشتركة › و بالحقيقة إنها تبتعد خلف الحد الأصغر. 


بما أن لغة التنفيذ المشتركة 1۸ تتحكم بكودك المصدري بأي حال » فإن الميكروسوفت اعتقدت أنه من الجيد أن تملك السيطرة على بيانات الكود 
المصدري أيضا . يعمل إطار عمل الدوت نت هذا من خلال نظام الأنواع المشتركة )C158(‏ "عأكر؟ ممرآ صمصصهع» الذي يعرف أنواع 
البيانات الأساسية وآلية البيانات المستخدمة في برامج الدوت نت. وهو يتضمن جميع أنواع القيم: العدديةء السلاسل النصية والأنواع المنطقية . وهو يعرف 
أيضاً الكائن أ #زطه»وهو وحدة تخزين البيانات الجوهرية في الدوت نت . 

يقسم نظام الأنواع المشتركة C۲5‏ جميع الكائنات إلى مقدارين كبيرين . يدعی المقدار الأول: الأنواع ذات القیمة s٥مرا‏ ٥ں‏ اج۷ءویخزن البيانات 
الفعلية الصحيحة في الخانات . إذا كان لديك قيمة عددية صحيحة ٣696ا"‏ 32بت أط-32› فإنها تدخل التعديل في خانة نوع القيمة › الجاهزة لاستخدامك 
المباشر. ويحتوي المقدار الآخر: الأنواع المرجعية كهمرا 8٥٠٠f8۲ه٠.‏ عندما تنظر في هذا المقدارء فإنك ترى خريطة تخبرك أين تجد البيانات الفعلية 
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بطريقة ما في ذاكرة الكومبيوتر. ومن الواضح أن الأنواع ذات القيمة هي المرجحة وهي أبسط للاستخدام » وهي كذلك» ولكن تصاحبها العديد من 
القيودءالتي لا تفرض على الأنواع المرجعية. 

يمكن للمكونات و البرامج المكتوبة باستخدام نظام الأنواع المشتركة القياسي أن تتبادل البيانات مع بعضها البعض بدون أي عوائق hindrances‏ أو 
قیود. (يسقط القليل من أنواع بيانات الدوت نت خارج الجوهر ”06ء“ لأنواع نظام الأنواع المشتركة » لكن عليك أن تتجنبها فقط و خاصة عندما تريد أن 
تتفاعل مع المكونات التي يمكن أن تستخدم جوهر الأنواع لنظام الأنواع المشتركة فقط. ) عندما تكتب تطبيقاتك في الفيجوال بيسك » فإن معظم كودك 
سیظهر في فئات.ءهووهاه. والفئات هي أنواع مرجعية وهي تتضمن کو ق ا المصاحب .إن قيم البيانات الموجودة في فئة ما معظمها 
على الأغلب الجوهر لأنواع بيانات نظام الأنواع المشتركة » لكن يمكن أن تحتوي أيضا على الكائنات التي تصممها في مكان آخر في تطبيقاتك .وتتضمن 
الفيجوال بيسك أيضا التراکیب ,وع ں)اruc gsi‏ أنواع قيمة تنفيذ التراكيب» وتتضمن أيضاً كل من البيانات و الكود. 

الفئات و التراكيب هي تماما نوعان من البيانات / الكود المتوفرة في الفيجوال بيسك . الواجهات هي فئة وهياكل تركيب structure skeletons‏ 
وتتضمن الواجهات تفاصيل تصميمية لما يجب أن يظهر في تركيب أو فئة مترابطة » ولكن لا تتضمن أي تنفيذ فعلي أو كود شغال. تعرف التفاريض 
إجراء ما بدون تنفيذ (توقيع ”۲6 ںاة٠وأء“)»‏ ويتم استخدامه لدعم الأحداث sأم‏ هه »هذه الأعمال(الممهد لها من قبل المستخدم » ونظام التشغيل »› أو 
كودك ) التي تخبر كودك ۸0W!”‏ )۲مس 0 ه6“. الوحدات البرمجية كع اں لمهي مقاطع من الكود والبيانات » ولكن لا تشبه الفئات والتراكيب › 
وإنه ليس بإمكانك أن تنشئ كائنات مستقلة منها . مجمو عة العدادات ء0اأة۲مص نمع هي مجموعة مرتبطة بالقيم الصحيحة » و هي عموما من أجل 
الاستخدام كقائمة من الاختيارات . 

في لغة الدوت نت »إن جميع هذه المصطلحات (فئة ووهاع › تركيب عا ںاع ٣ء‏ » واجهة #عهfمint‏ »تفويض مأaوعاعل‏ › وحدة برمجية 
module‏ » العداد ation‏ erمصumمe)‏ تعرف إجمالا بالأنواع .types.‏ من المحتمل أنك عرفت للتو أن للدوت نت عناصر مشوشة فيها: لذلك لن تشتر 
كتاب يتعلق بها إن كانت سهلة. ولكن على الرغم أن جميع التقنيات معقدة › فإن الكلمة البسيطةء نوع ممرا» هي التي تسبب الإرباك الأكبر .إنك ستلاقي 
بعض الخوف طيلة هذا الكتاب عند قراءته كل مرة . المشكلة : ليست فقط أن النوع يشير إلى تلك العناصر الجوهرية لنظام الأنواع المشتركة C18‏ لكن 
يتم استخدامه عند التحدث عن أنواع القيمة الخاصة بالفيجوال بيسك (تدعى أكثر الأحيان الفيجوال بيسك بأنواع البيانات ”همر هأجك“) . واللقب 
للتراكيب هو أنواع معرفة بالمستخدم ”,كممر "6١‏ اهل-۲هوں“ ومع ذلك يوجد التباس آخر لاستخدام النوع ”.همر]“. يذكر المبرمجون الذين استخدموا 
الفيجوال بيسك قبل تجسيده للدوت نت أيضا أن النوع ”همر“ كعبارة لغوية اعتادت أن تنشئ أنواع معرفة بالمستخدم esضصtyp user-defined‏ . 
على الميكروسوفت أن تستخدم بعض الكلمات الأخرى للعالم بدلا من نوع همر كالفئات وعوءوام » الواجهاتومعع؟۲ مام › العدادات 
85اumer en‏ » وهكذا . سيكون اختيار أي كلمة أفضل بما أنه سيتم استخدامها أحيانا لتناقش البرمجيات . لكن ”٥مر†“هو‏ الكلمة المختارةء لذلك 
من الأفضل لك أن تعتاد على رؤيتها . 

تتألف عادة أعضاء النوع من حقول بيانات بسيطة و إجرائيات كود » لكن يمكنك أن تدخل أيضا أنواع أخرى كأعضاء . حيث أنه » يمكن لفئة ما أن 
تتضمن فئة ما متداخلة لماومم إذا دعت الحاجة لذلك . تدعم أشكال محددة فقط التداخل . أتحدث أيضا عن مستويات الوصول sاeveا access‏ في هذا 
القسم . کل عضو يملك مستوى دخول و الذي يقول ما الكود الذي يستطيع استخدامه ذلك العضو يوجد خمسة مستویات دخول 5ھ ٬تتراوح‏ من 
العام (شخص ما و إخوته يمكن أن يستخدموا الأعضاء ) إلى الخاص هأو۷أإم (عليك أن تدخل النوع كي تعرف أنه موجود هناك) . الفصل السادس 
يناقش نظام الدوت نت بأجل التفاصيل › المتضمنة المعلومات التي تحتاجها عن الفئات › والتراكيب › إلخ. 


إن الكمبيوترات بدقة مبهمة تماما . في حين أنني أستطيع العد بجميع الطرق حتى العدد 17 » أما الكومبيوتر فأعظم قيمة للعد هي العدد 1 : إنه يعرف فقط 
الأرقام 0 و1 . تتضمن وحدة المعالجة المركزية ل۴ مجموعة من العمليات البسيطة المستخدمة لمعالجة الأرقام 0 و1ء وعمليات أكثر قليلا تقارن 
بين 15و05 بطرق معقدة . والحيلة العظيمة الأخيرة للكمبيوتر هي قدرته على نقل 05و15 من و إلى الذاكرة . تأكد أنه يعمل هذه الأشياء بسرعة الضوء 
تقريبا » ولكن هل يستطيع أن يحسب 3.14 حتى 3 مليون خانة عشرية ؟ حسنا بالفعل إنه يستطيع. لا تعرف الكمبيوترات أي شيء عن حروف الأبجدية › 
وهي بحق يمكنها معالجة الأرقام 0 و 1 فقط » ومع ذلك أستطيع استخدام الكمبيوتر هنا لكتابة كتاب ربح جائزة .award-winning‏ إنها القدرة على 
تصنيف قيم البيانات البسيطة 1 بت و المعاملات داخل مكتبات وءه ۲جط معقدة بشكل متزايد للتخصص الوظيفي التي تجعل فائدة الكومبيوتر ممكنة. 
يبنى عمل إطار الدوت نت على عشرات من التخصص الوظيفي المعقد بشكل متزايد. CES‏ 
ونظام النوع المصاحب لها يمثلان الجوهر لإطار العمل . يتضمن إطار العمل بحد ذاته جميع التخصص الوظيفي الأساسي الذي يحتاجه لتتمكن من 

تضيف 2 إلى 2 وتحصل بشكل صحيح على 4 . وبصفتك مطور تطبيق عمل ماء ستقضي وقتا طويلاً لعمل ذلك فقط. TE‏ 
ما أكثر تعقيداً > شيء ما والذي تعرف بعض البرا مج التي نفذته » كتصنيف قائمة من الأسماء أو رسم دائرة ملونة على نموذج ما؟ لتحصل على الجواب » 
اذهب إلى كعأاج۲ طا sوجاع»مكتبات‏ فئات الدوت نت . تتضمن هذه المكتبات › المنصبة مع إطار العمل » الكثير من ( المعقدة بشكل متزايد )التخصص 
الوظيفي المكتوب سابقا والذي ليس عليك أن تكتبه من الخربشة. 

يوجد مكتبتا فئة في الدوت نت : مكتبة الفئة القاعدية Base Class Library (BCL)‏ ,Snتبة‏ İة‏ إ¡¦طار FrameworkClass Library Jazll‏ 
.)۴١1(‏ مكتبة الفئة القاعدية أصغر » وتحتوي الميزات الأساسية الأعظم التي لا يستطيع البرنامج العمل بدونها . وهي تتضمن فقط تلك الفئات التي هي 
ساس واجب لدعم التطبيقات على إطار العمل إذا دعمت الميكروسوفت ذلك» تقول» نفذ إطار العمل إلى نظام تشغيل الكمبيوترات الشخصیة ×ں ٣اا‏ 
مكتبة فئة إطار العمل أكبر» و تحتوي كل شيء آخر اعتقدت الميكروسوفت أنك تريد أن تملكه في برامجها » ولكنه ليس أساسي بشكل جوهري ليدخل في 
مكتبة الفئة القاعدية . ويوجد فئات كثيرة جداً في مكتبة الفئة القاعدية » بالآلاف من الفثات ( نعم » بالآلاف !) » العدادات » الواجهات ؛ وأنواع أخرى 
محتواة في مكتبة الفئة القاعدية ومكتبة فئة إطار العمل » ستعتقد أنه من الصعب أن تجد فقط الفئة التي تحتاجها . لكن ليس ذلك صعبا » على الأقل ليس 
صعبا جداً . يتضمن إطار عمل الدوت نت ميزة ما مسماة namespaces ءlaÎلl ٽlءlضف ã‏ . تظهر جميع الأنواع في الدوت نت كهرم - ترکیب متثل 
الشجرة ‏ مع القليل فقط من المدخلات ت الدنيا عند الجذر . كل عقدة هلمم في الهرم هي فضاء اسم . وتعرف أي فئة أو نوع آخر في المكتبات بتسمية جميع 
فضاءات الاسم بشكل وحيد » من أسفل الجذر إلى فضاء الاسم المحلي الذي يحوي الفئة » بفصل كل عقدة بنقطة (.) . بخلاف معظم الأهرام التي لديها 
EC a a SS‏ 
ويتضمن العديد من الفئات › ولكنها تتضمن أيضا عقد هرمية مباشرة متعددة (فضاءات اسم) . بما أن إطار العمل يتضمن ميزات لكل من تطوير تطبيق 
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قاعدة الويندوز ل ٥2sةط‏ sسەك” W۷‏ و قاعدة الانترنت dعءaط-ط we‏ ءفإنه يوجد فضاءات اسم تحتوي ميزات متطورة لویندوز محدد-sس0 Wi"‏ 
fic‏ speciو‏ لانترنت محدد عاfا‌ممء-طعw‏ . تظهر فضاءات الاسم فقط ضمن فضاء اسم النظام ہماور؟» وتدعی sس0Wل۸‏ |۷ و ۷66 . وجمیع 
الكود المرتبط بالنماذج المعروضة على الشاشة في فضاء الاسم وس0 ۷|١0‏ يظهر في فضاء الاسم ء"۲٠۴‏ » وضمن فضاء الاسم هذا الفئة الفعلية التي 
تنفذ نموذج ما» مسمی ۴0۲۳١‏ في الفيجوال بيسك › تعرف فئة ما بتحديدها بكل فضاءات الاسم التابعة لها »> مبتدئا من فضاء اسم الجذر التابع لها . فئة 
النموذج إ۴ لديها الاسم المحدد الكامل إلتlئي‏ : System.Windows.Forms.Form‏ 

توجد جميع الفئات و الأنواع في مكان ما في الهرم » رغما من أنه لا تنحدر كل فئة من النظام. هور . تظهر العديد من الميزات الداعمة المحددة 
للفيجوال بيسك في فضاء الاسم عأوجua|8ء۷i.اMicrosof»‏ الذي لديه "اf۴موما۲ Mi‏ " كعقدة جذر خاصة به بدلا من "النظام 5/56۳ " عندما تنشئ 
مشاريع جديدة في الفيجوال بيسك » الاسم للمشروع هو ءبقيمة ابتدائيةء عقدة المستوى الأعلى |ع۷ءا-مه] في الهرم . إذا أنشأت تطبيق sسم‏ لہا۷ جديد 
مسمى 0۸1| icaاsApp Window‏ » فإن نموذج القيمة الابتدائية “۴٠۲١17‏ لديه الاسم المحدد الكامل التالي : 

WindowsApplication 1.Form 1 

اسم الفضاء للتطبيق الجديد ليس مجرد فئة ثانية ووواء-ل١"‏ 58600 ملحقة منحدرة من فضاء الاسم ٠#اورك.‏ يتم دمجه بشكل كامل في هرم فضاء اسم 
الدوت نت الكامل: فضاء الاسم 11 ica†|0اsApp Window‏ هو عقدة جذر » فقط مثل عقد الجذر ۵۳ ءر؟ و )مما Mi‏ »۰ یتضمن الفیجوال بیسك 
الميزات التي تدعك تغير القيمة الابتدائية لفضاء اسم تطبيقك » أو مكان واحد من فئات التطبيق في فضاء اسم ما خاص . يمكنك حتى أن تضع فئات 
تطبيقك في فرع فضاء اسم النظام هاور . تغيير 0۸1| icaاWindowsApp‏ إلى النظام.ممerAمMy8up. System‏ يتحرك من ۴٥۳۳۹‏ إلی: 

System.MySuperApp.Form 1 

إذا كان تطبيقك بشكل فعلي عنصر أو مكتبة موجهة للاستخدام في البرامج ءفإن فئات تطبيقك ستظهر في فضاء الاسم الذي حددته عندما حمل البرنامج 
الآخر عنصرك في منطقة التطبيق الخاصة به.إن كودك سيبدو كجزء من فضاءات الاسم Qعأاممuء-ا؟osoاMic‏ . على الرغم من أنك تستطيع أن 
تضيف فئاتك إلى فضاء اسم النظام صءاوركءفإنك سوف تتعرض لغضب مبرمجي الدوت نت الآخرين . يتم فرض فضاء الاسم System‏ لیکون 
“system”J‏ (اقرأً مزود الميكروسوفت ) ميزات › وهو ذلك . توجد أيضاً فرصة ما وهي أنه ربما يستخدم بائعان نفس مسار فضاء الاسم . لذلك › لتجنب 
تناقضات فضاء الاسم المحتملة و النظرات الدنيئة من المبرمجين الآخرين »› عليك أن تسمي فئات تطبيقك مثل : 

CompanyName.ApplicationName. ClassName 

كفئة وحيدة أو نوع آخر لا يمكن أن يتم إفساده من خلال فضاءات الاسم المتعددة > حتى ضمن نفس فرع الهرم . على أية حال » يمكن أن يتقاسم نوعان 
أو فئتان الاسم المشترك في فضاءات اسم مختلفة »> حتى ضمن نفس الفرع . 

تظهر جميع فئات مكتبة الفئة القاعدية ومكتبة فئة إطار العمل متمازجة في كل مكان في هرم فضاء الاسم الكامل . هذا يعني أنه لا يمكنك بالضرورة أن 
تقول فيما إذا كانت فئة مخصصة هي من مكتبة الفئة القاعدية أومن مكتبة فئة إطار العمل . بصراحة »› لا توجد مشكلة : فلن يهتم كودك من أي مكتبة تأتي 
فئة ماء طالما أنها متاحة للاستخدام على شبكة أجهزة المستخدم . 

فقط قبل إصدار الفيجوال استديو 2008 » أعلنت ميكروسوفت أنها ستجعل الكود المصدري أكثر توافقا مع مكتبة فئة إطار العمل النسخة 3.5 المتاحة 
لمراجعة المطورين . وهذا يعني أن المبرمجين الذين يريدون معرفة كيف تصنف الميكروسوفت قائمة من أسماء ما في الذاكرة أو ترسم دائرة ملونة على 
نموذج ما والذي سيحصل على الأقل على نظرة جزئية عن كيفية عمل ذلك . 


التجميع هو "وحدة نشر" لأجزاء تطبيق أو مكتبة الدوت نت . في % 99.9 من الحالاتء اللجميع هى بساطة ملفا درت نت قال اة ( قبم, an‏ 
ها) أو فئات مكتبة الدوت نت أو أنواع أخرى (هاا؟ ااك. ه) . من الممكن أن ت تقسم التجميع بين ملفات متعددة » لكن عادة هو ملف واحد من أجل مجمع 

واحد .إن ما يجعل ملف قابل للتنفيذ أو ملفات أخرى تجميع ما هو وجود کشف manifest‏ . من أجل تجميعات ملف وحيد »single-file‏ فإن ا 
tكanifص‏ يظهر مباشرة في الملف : ويمكنه أن يظهر أيضا في ملف ما بحد ذاته . الكشف هو قطعة ما كبيرة من البيانات التي تسجل تفاصيل هامة 
حول التجميع › المتضمن اسمها > معلومات إصدارها ء قيم تقافتها المبدئية » ومعلومات عن أنواعها و مجمعاتها الخارجية المرجعية » و قائمة ما من جميع 
الملفات الموجودة في التجميع . لن تميز لغة التنفيذ المشتركة C1۸‏ تجميع ما بدون كشفه › لذلك لا تفقده . يمكن أن تتضمن المجمعات اسم قوي و١‏ ۲0ء 
اختياري . وهذا يساعد على ضمان سلامة و أصل تجميع ما خلال توقيع رقمي متعلق بالكشف. يستخدم الاسم القوي مفتاح عام للكتابة السرية 
ليضمن أن التجميع منقطع النظير و لا يمكن التلاعب به ت تتضمن الفيجوال استديو و إطار عمل الدوت نت أدوات تتيح لك إضافة اسم ما قوي للتجميع . 
عندما د تنشر تطبيقك » سوف تعرض بشكل عادي جميع ملفات التجميع › والملفات التشكيلة › و أي ملفات متعلقة خاصة بتطبيقك في فهرس تنصيب 
التطبيق › > تماما كما في الأيام الجوراسية القديمة قبل الدوت نت. صممت المجمعات المشاركة لكي يتم استخدامها من قبل أكثر من تطبيق واحد على آلة 
مفردة يمكن أن يتم تخزينها في ذاكرة التجميع العالمي المخفية Cache )6۸٣(‏ yاAssemb‏ اaطداG.‏ يجب أن تملك جميع المجمعات المتركزة في 
ال 6۸€ أسماء قوية . يمكن أن تسمح بعض الأنظمة فقط لمدير النظام أن يضيف التجميعات إلى ال 6۸€ . 


يتم إحضار المجمعات لك بالحرف 77 . بالإضافة إلى الكشوف و أعضاء نوع ماء تحتوي المجمعات أيضاً توصيف البيانات aأةلهاهص.‏ إن كود التطبيق 
و كرفت الات رة في تين ا مان رد لگن ر الياقات الخ ا في الفيجوال بيسك المتعلقة بالكود المصدري : ومن أجل كل نوع و عضو 
ETS GO CT O OT‏ 
.pre-.NET‏ ما الاختلاف الذي يجعل مترجم الفيجوال بيسك الأن يربط المعلومات الإضافية - توصيف البيانات - بكل نوع وعضو في التجميع. يو د 
توصيف البيانات الاسم من المحتوى المساعد › والمعلومات حول أنواع البيانات المطلوبة » ومعلومات عن وراثة فئة o‏ 
قبل أن يُستخدم العنصر من قبل المستخدم أو البرمجيات الأخرى . يعزز كودك المصدري للفيجوال بيسك توصيف البيانات من أجل أي عنصر لتجميعك 
من خلال المواصفات ءع)ں طا ٣))ج‏ . ينتج توصيف البيانات بوساطة مواصفة ما هي أكثر من مجرد عدد 0| ما. SaaS‏ الدوت نت كاملة 
مع المنطق المساعد و قيم البيانات الخاصة بها. يمكن لأي كود دوت نت والذي يعرف كيف يعالج المواصفات أن ي يفحص المواصفات من أجل عضو أو 
نوع ما و يتخذ حدث كما تدعي حاجته. وهذا يتضمن الفيجوال استديو » ومترجم الفيجوال بيسك » وتطبيقائك التقليدية الخاصة بك . كيف يكون مثال ما 
عادي : يتضمن إطار عمل الدوت نت مواصفة ما مسماة عا طأ٣)) tA‏ ا0ط تتيح لك هذه المواصفة أن تحدد أعضاء أو أنواع تجميعك وكأنها 
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مهجورة أو غير مدعومة منذ زمن طويل . ( تستخدم الفيجوال استديو هذه المواصفة لتعرض تحذير ما كلما حاولت أن تستخدم ميزة ما خارجة عن 
التاريخ عاهل-؟ه-اه لكل من مكتبة الفئة القاعدية أو مكتبة فئة إطار العمل). ولتستخدم المواصفة » أضفها إلى عضو ما من تطبيقك مستخدما أقواس 
زاوية الشكل (على الشكل <>): 
Class MyClassWithOldMembers‏ 
<ObsoleteAttribute () > Sub DoSomeWork ()‏ 
ERA SUG‏ 
SMC. CLES‏ 
يعرف هذا الكود فئة ما وحيدة (sءإءطصء3×M‏ 101 )uyc1ass«N 1t‏ بإجراء ذو عضو ما وحيد (٤إه»ء«ه5ه<5))»‏ إجراء ما والذي يعمل بوضوح 
عمل ما. يتم ربط الإجراء بمواصفة عاط A٤۲‏ عاهامsط0.‏ بواسطة الزبون » تنتهي جميع أسماء المواصفة بالكلمة عا ں طآA)۲‏ . يمكنك أن تهمل هذا 
الجزء من الكلمة إذا أردت » طالما أن الكلمة الناتجة لا تتناقض مع أي كلمة محجوزة في لغة الفيجوال بيسك : 
Class MyClassWithOldMembers‏ 
<Obsolete ()> Sub DoSomeWork ()‏ 
ENA SUS‏ 
End Cless‏ 
عندما تترجم الفئة و تخزنها في تجميع ما ءفإنه يتم تخزين المواصفة <ع) ں ط|ا٣)teAtاbso‏ 0> كجزء من تعريف DoSomeW ork)‏ . يمكنك الآن أن 
تكتب تطبيق فيجوال بيسك منفصل والذي يمسح تجميع ما و مخرجات الاسم و حالات لكل نوع وعضو يجده » وعندما يصادف ذلك البرنامج التحليلي 
العضو القديم » سيكتشف عا ں طأ٣)†Aهtهاد0bs‏ في توصيف البيانات » ويطبع الحالة : 
DoSomeWork Procedure: Obsolete, don't use it!‏ 
يتم تصميم معظم المواصفات مع غرض ما خاص في العقل. تأمر بعض المواصفات الفيجوال استديو أن يعرض الأعضاء لفئة ما بطرق محددة . من 
المحتمل أنك عملت سابقا مع ميزات تحرير النموذج و١‏ اال ه-٠0۲]‏ للفيجوال استديو لتصمم تطبيق بسيط لسطح مكتب ويندوز عندما تضيف تحكم ما 
(مثل زر ما أو صندوق قائمة) لنموذج ما و تختار ذلك التحكم > فإن الفيجوال بيسك ستتركك تحرر التفاصيل من ذلك التحكم من خلال منطقة لوحة 
الخاصيات ءهأاممهم۴۲( انظر الشكل التالي ). 


vh Windowshpplication1 - Microroft Visual Studio = [Form1Lvb [Design] 
OD Fle Edit View Project Build Debug Dam Tools Window Help 


a‏ ا 3-e‏ د ل2 اكاد اك ها ٠ل a‏ و لن 
2 
Î Faml lel ENE‏ 
ص 8 
Bulnl Db‏ __ 
T7‏ 
POE ee‏ 
IName]‏ 
Indices the name used in code ta identify‏ 
the obje‏ 
Rasdy‏ 


يتم تنفيذ زر التحكم ١0ا8‏ كفئة ما » ويظهر العديد من أعضاء فئته في لوحة الخاصيات هاا 6مه۴ » ولكن ليس جميعها . عندما تم تصميم فئة 
الزر )ں8 ٠»‏ فإنه تتم إضافة المواصفات إلى أعضائه التي تخبر الفيجوال استديو أي الأعضاء يجب أن يظهر في لوحة الخاصيات كعا) «Prope‏ 
وأي منها يجب أن لا يظهر . من الواجب على الفيجوال استديو أن تفحص هذه المواصفات » و تعرض الخاصيات المطلوبة فقط. 


كما لديك » تطبيقاتي سليمة من تحريراتها الأولية » ولا أجد سبب لأعدلها أو أضيف ميزات لها . ولكن يوجد تنظيمات تطوير برمجة متضمنة شركة 
ضخمة واحدة لعمل ذلك » ولكي لا أسبب إحراج » سوف أشير إليها فقط بواسطة حرفها الأولي س الذي يلتمس الحاجة إلى تفوق ”مں-هه“ 
المتنافسين بواسطة الخروج مع التوافقية المحسنة ”۲0۷8۵م١|“‏ عن سابقاتها متخلية عن عروض البرامج . دعنا نقول أنه حدث الحرف ”۷“ ليملك 
معالج كلمة شائعة ما والتي تتضمن توافقية 1.0 من فحص تهجئة عنصر ما. يحدث أيضا الحرف ”0“ ليبيع أداة بريد ما و التي تعتمد بشكل محدد على 
التوافق 1.0 من نفس ذلك العنصر المشارك . إذا حرر الحرف ”0“ في عرض رجل منافس ما » تحديث ما لمعالج الكلمة و فحص تهجئة العنصر (الآن 
توافق 2.0)» فماذا يحدث لقدرة فحص تهجئة أداة البريد ؟ 

رغما من أن هذا لا يحدث دائما في الحياة الواقعية . ولكن إذا حدث » التبديل لأساس عنصر ما متشارك مع عنصر أحدث. لكن يمكن أن يسبب توافق 
متضارب إلى حد ما مشاكل حقيقية . المشكلة المسرودة هي الانتشار لتوافقيات متعددة لعنصر ما منفرد على نفس شبكة الأجهزة » جميعها في اتجاهات 
مختلفة . هل يمكن أن تحذف أي منها بشكل آمن ؟ 

تحل الدوت نت هذه المشاكل من خلال التوافقية in14‏ , تعرف جميع المجمعات التي تستخدم العناصر المشاركة بالضبط أي توافقية لعناصر 
مشاركة تطلبها . على الرغم من أنه يمكن أن يتم تصوير تطبيق ما ليستخدم توافقية فيما بعد › فإنه سيستخدم التوافقية المحددة بشكل أصلي فقط من 
عنصر مشارك ما افتراضي . يمكن أن تتم إضافة التو افقيات المتعددة من عنصر منفرد مشارك ما إلى ذاكرة التجميع العالمي المخفية »G۸٥‏ وتدعى 
ميزة ما جنبا إلى جنب عل اء-رط-هلاوءبالانتشار ٠٣٥٠۲‏ 0۷|امهل.تؤكد لغة التنفيذ المشتركة أن التطبيق الصحيح يرتبط مع العنصر الصحيح .حتى أنه 
يمكنك أن تنفذ بنفس الوقت التطبيقات التي تستخدم توافقيات مختلفة لنفس العنصر. 
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تعرف الآن بشكل جيد أن كل شيء موجود لتعرف أكثر حول الدوت نت لولا موضوع البرمجة المزعج. قبل التفتيش في كود فعلي ما ء دعنا نأخذ 
استراحة صغيرة ونفحص مدى عمر تطبيق ما » من البداية إلى النهاية (انظر الشكل التالي): 


(b) (e) (e) 


ET 
0-Ê 
Of 


1- إنك » كمبرمج » مسؤول عن تحضير العناصر الأساسية (ج) من التطبيق . من أجل برامج الفيجوال بيسك » هذا يعني إنشاء واحد أو أكثر من ملفات 
الكود المصدري مع امتداد (ط.) . يمكن أن تتضمن عناصرك أيضا ملفات دعم أخرى » مثل ملفات مصدرية ( ملفات نصوص و رسومات › وغالبا ما 
تستخدم دعم اللغات المتعددة (. 

2- يتم التلاعب بتطبيقك بوساطة مترجم الفيجوال البيسك كما في (ط) . النتيجة هي تجميع ما » يكمل مع كشف ا5ه؟أ/ج" ما و توصيف البيانات 
ه†daهtمص.‏ إن النتائج بالفعل هي لغة ميكروسوفت وسيطة 1511 شبه مترجمة وتتضمن الإصدار الجاهز للتنفيذ عاںءم×ه-ه)-رلهمم من أنواع 
وأعضاء الكود المصدري الأصلي › المتضمن كافة أسماء النوع و العضو . يمكن أن تكون كافة هذه المحتويات ناقصة الترجمة ”Qه|أم‏ 0هل“ 
(معادة إلى اللغة الوسيطة الكاملة » ورغما من عدم إشباع الفيجوال بيسك) مستخدها أداة ما مسماة #×ع.5ه4ل|¡ (مفكك اا" 58ءهءا0 لغة 
الميكروسوفت الوسيطة ) » التي يتم إدخالها مع إطار عمل الدوت نت . بما أنه من المحتمل أنك لا تريد لأحد ما من أن يفكك تطبيقك وينظر إلى الكود »› 
فإن الميكروسوفت (أو أي طرف آخر ) تدعم أيضاً ٥20۲‏ وں؟طه » الذي يمز ج بدرجة كافية المحتوى من كودك ليجعله صعبا بما فيه الكفاية حتى 
يستطيع إعاقة نظرات المتطفلين . 

3- يتم نشر المجمع (ء) إلى شبكة أجهزة المستخدم . يتم استخدام طرق مختلفة قليلة لتنشر التطبيق › المتضمن (1) إنتاج حزمة تنصيب مثبت الويندوز 
القياسي ٠‏ (2) إنتاج توزيع ما مع" 0 ءا : أو (3) إنجاز تنصيب نسخ ما إمه٥×‏ » والذي لا يتضمن شيء أكثر من نسخ التخن التنفيذي نفسه إلى 
الجهاز الهدف . لايوجد مشكلة في أي طريقة نشر تختارها › وإن وقت التنفیذ ٥٣ں‏ ۲.. الخاص بالدوت نت في (4) يجب أن يتم تثبيته على 
شبكة أجهزة المستخدم . 

4 المستخدم يأكل -أقصد أنه يشغل - البرنامج كما في (ه) . تعمل لغة التنفيذ المشتركة لمجمع لغة ميكروسوفت الوسيطة ترجمة نهائية على الفور-|-اءدز 
ما (1|ل)ء لتحضرها من أجل الاستخدام على المنصة المحلية . ومن ثم تعرض التطبيق للمستخدم » وتدير جميع سمات التطبيق عندما يكون مشغل . 
يختبر المستخدمون مستوى المتعة والرضا المصادف بشكل قليل عند استخدام تطبيقات برمجية أخرى . 
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Introducing Visual Basic يم الفيجواJ بك‎ 


كمال ماء دعنا نقول أنك تلقيت طلب ما من قسم بيع البرامج لعمل برنامج يقلب جميع الحروف في أي قطعة كبيرة من نص مجهز للبرنامج .لذلك أولا 
اكتشف المنطق › وتم نفذه في الفيجوال بيسك . باستخدام شبه الكود(الكود المزيف) pseudocode‏ لغة برمجة اصطناعية (مفتعلة) التي تركبها بنفسك 
لتساعدك على كتابة البرامج (“ بإمكانك أن تضع مخطط (او مسودة آولية (sketch‏ خارج هذه المهمة الأساسية (مع ترقیم الاسطر الرئيسية): 
1 احصل على النص الأصلي (أو سلسلة حرفية) من المستخدم . 
2- إذا لم يزودك المستخدم بأي محتوى » عندئذ اخرج حالا . 
3 حضر مكان ما للسلسلة الحرفية المعكوسة › فارغ حاليا . 
4 كرر التالي حتى تكون السلسلة الحرفية فارغة : 
5- انسخ الحرف الأخير من السلسلة الحرفية الأصلية المتبقية › 
6- ضع ذلك الحرف على نهاية السلسلة المقصودة 
7 قصتّر السلسلة الأصلية » بإسقاط الحرف الأخير . 
8- [أنهي ڌ قسم التكرار] 
9 دع المستخدم يرى السلسلة الحرفية المقصودة 
يمكنك أن تكتب هذا المنطق بطرق متعددة : وهذا مجرد مثال واحد فقط . يمكنك الآن أن تحول الشبه شفرة هذه إلى لغة من اختيارك: في هذه الحالة ء› 
الفيجوال بيسك (لا تقلق حول تفاصيل القواعد الغوية حتى الآن): 
originalText = InputBox ("Enter text to reverse.")‏ 
If (Len (originalText) = 0) Then Return‏ 
finalText = ""‏ 
DO Wle (OITA TESE € N)‏ 
oneCharacter = Right (originalText, 1)‏ 
finalText &= oneCharacter‏ 
OEIGinRnaA Nex > Ter E(OEIGINRA ITO E |‏ 
Ke (Or Oma EXE) >)‏ 
Loop‏ 
MsgBox ("The reverse is: " & finalText)‏ 


SAITO OTE TETER 


eee) 


ان هذا الكود المصدري source code‏ جاھز الآن ليتم استخدامه في برنامج الفيجوال بيسك . و يوضح أيضا السمات الأساسية المتعددة لكتابة الكود : 

٠‏ تدعى الخطوات المفردة من التعليمات التدريجية معاء-رط-مهاء عبارات امم" هاهاء . و في الفيجوال بيسك»ءتظهر كل عبارة على سطر 
ما بنفسها , يمكنك قطع العبارات الطويلة إلى سطور متعددة بوصل السطور بفراغ مزدوج تحت كلمة ما #إ0ءءمل"ں-هعهمء» كما هو 
واضح في السطر 7 من الكود .عندما يتم نشر عبارة منفردة عبر سطور متعددة في هذه الحالة › فإن العبارة الكاملة تدعى أحيانا بسطر منطقي 
ا /aء/وم/‏ .بما أنه غالبا ما يتضمن سطر منطقي مفرد ما عمل فيجوال بيسك ابتدائي مفرد ما فقط (مثل عمل ۴| أوه0 » أو استخدام 
أعمال الإسناد المختلفة لإشارة المساواة [=]) » ويشار أيضا إلى هذه الأعمال كعبارات. 

ه تتم معالجة عبارات الكود كل واحدة بدورهاء من الأعلى إلى الأسفل . على أي حال » تبدل عبارات محددة التدفق العادي للبرنامج من الأعلى 
إلى الأسفل إ0اامط-هt-مهt0‏ » كما تم عمله بالكتلة م0 10ا...٠ااW۴‏ 00 على السطر 4 و السطر 8 من الكود النموذج. وهكذا تدعى 
العبارات بعبارات ضبط التدفق اه٣أ٣هء‏ سه|؟ » و تتضمن الحلقات (تكرار قطعة الكود)» والشروط (بشكل اختياري معالجة قطعة ما من 
الكود المؤسس على مقارنة ما أو نتيجة محسوبة ) » والقفزات (تحريك بشكل مباشر إلى قسم آخر من الكود) . 

: يتم تخزين البيانات في المتغير ات وع/طو//و › والتي تسمى حاويات لقيم البيانات . تتضمن قطعة الكود النموذج ثلاث متحولات وهي‎ ٠ 
تخزن جميع هذه المتغيرات نص (سلسلة حرفية ) بيانات . يسمح لك نظام النوع‎ » fina ا‎ ext oneCharacter« original Text 
بأن تنشئ متحولات لأربع أنواع رئيسية من قيم البيانات الأساسية وهي: نصية ×ه)(كل من الحروف المفردة‎ )C15( المشترك للدوت نت‎ 
ةيقطنملا٬ و السلاسل الحرفية الطويلة ) › أعداد s؟هط ن" (كل من القيم الصحيحة والعشرية ) › التواريخ هعلو الأوقات)‎ 

5ەا0ه8(قيم صح أو خطأ) . يمكنك أيضا أن تنشىئ أنواع معقدة أكثر من البيانات بتجميع الأنواع الأساسية . 

ه ثخزن البيانات في متحول ما من خلال إسناد ما.؛م"”وأوءه . يتضمن هذا بشكل عام توظيف اسم متغير ما على جهة اليسار من عملية إسناد 
ما assignment operator‏ (= ) » و وضع البيانات أو الحسابات لتخزن في ذلك المتغير على جهة اليمين من نفس إشارة المساواة تلك . 
تخزن العبارة " " = ٠×‏ اهم |؟ على السطر 3 سلسلة حرفية ما فار غة ("") في المتغير ٠×‏ ٠ا2٣f1.‏ وتعرض عبارة الإسناد =& على 
السطر 6 قواعد إسناد لغوية مختلفة نوعا ما . 

ه يمكن أن تتضمن العبارات استدعاءات الدالة «function calls‏ وقطع من التخصص الوظيفي المسبق الكتابة » وتقع جميعها تحت اسم مفرد . 
تعمل استدعاءات الدالي حزمه ة عمل EE‏ بعدئذ تعيد return‏ نتيجة نهائية ¢ وقیم بیانات . يتم تح أسماء الدالي بمجمو عة من الأقواس ¢ التي 
يمكن أن تتضمن الصفر أو معاملات نسبية كأ" "دوه أكثر » وقيم بيانات شرطية مدعومة بكود الاستدعاء الذي يستخدمه الدالي ليولد 
نتائجه . يتضمن الكود النموذج أمثلة عديدة من استدعاءات الدالي » والمتضمنة الدالي ٤وأR‏ على السطر 5 . يعيد هذا الدالي نسخة ما من 
الحروف التي على أقصى اليمين اsەص‏ اہ rig‏ ن ا ر اکر . إنه يوافق وسيطين اثنين : السلسلة الأصلية من التي استخرجت 
الحروف من أقصى اليمين » و قيمة صحيحة ما تشير إلى عدد الحروف اللازمة لتعود . يعيد الكود (1 Right)original Text,‏ نسخة ما من 
الحرف المفرد على أقصى اليمين (1) من .originalText‏ 
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eS SS a‏ المصدري › عندئذ يمثل الدالي شيء صغير كمتغير: جميع النصوص لاستدعاءِ الدالي » من البداية لأسمائها إلى النهاية 
بأقواسها المغلقة » يمكن د نستبدل بمتغير ما والحاوي على نفس البيانات الناتجة ة. لا تظهر استدعاءات الدالي على جانب الجهة اليسرى من عبارة إسناد ماء 
رگن گن أن تظير رها في أي مكان آخر والذي سكن أن يظهر فة امغر , على ييل الال + > يمكن أن يستخدم السطران التاليان لاستبدال السطر 2 


: في التمودج‎ 
. '" Replacing > lf (len (GEGInNaAlLexXE) _ ÛU) Men ReCUEN 
° lengthOfText = Len (originalText) 
© If (lengthOfText = 0) Then Return 


ه بالإضافة إلى الدوال » تتضمن أيضا الفيجوال بيسك إجر ائيات ءع/Q‏ ع٤ .۶/٥‏ تحزم الإجرائيات ءع/ مء 7/٥‏ الكود المكتوب مسبقاً في حزمة 
معرفة » تماما كما في الدوال ك١‏ هاعم لf؟.‏ ولكنها لا تعيد قيمة. يجب أن يتم استخدامها كعبارات مستقلة : ولا يمكنك أن تستخدمها حيث ستستخدم 
استدعاء متغير ما أو دالي ما . الاستدعاء إلى ×0 98ء على السطر 9 هو مثال نموذجي لاستدعاء الإجرائية في الاستخدام . ( ×980ءهو 
دالي فعلي . 

يمكن أن يتم جعل الكود النموذجي المدرج سابقا أكثر فعالية قليلاً . في الحقيقة » من المحتمل بشكل كامل أن الميكروسوفت حصلت على مسودة أولية من 

هذا الكتاب » بما أنها تضمنت ميزة سلسلة الحروف المقلوبة string-reversal‏ اليمينية في الفيجوال بيسك › و سمتھا StrReverse‏ : 


originalText = InputBox ("Enter text to reverse.") 

If (Len (originalText) = 0) Then Return 

finalText = StrReverse (originalText) 

MsgBox ("The reverse is: " & finalText) 
ذلك صحيح : تضمنت الفيجوال بيسك سابقا ميزة السلسلة الحرفية المقلوبة » والبعض من كود المكتبة المكتوب مسبقا الذي أناقشه .تتضمن الفيجوال بيسك‎ 
الكثير مثل الدوال الجوهرية كرامند ٥أو٠ آ٣ )"| التي تعتبر جزء من اللغة » و التي تحزم التخصص الوظيفي المفيد المكتوب مسبقا. يظهر العديد من‎ 
والذي يتم صنعه بشكل أوتوماتيكي متيسر لكودك المصدري الخاص بالفيجوال بيسك عندما‎ » Microsم؟۴.۷اءu2|8‎ 2S٥ هذه الدوال في فضاء الاسم.‎ 

تنشئ مشروع فيجوال بيسك جدید . 


عمليا ما أطلبه من تطبيق الفيجوال بيسك الخاص بي ليعمل هو التالي : خذ البيانات من مصدر ما (لوحة المفاتيح » القرص الصلب » الانترنت › إلخ) 
ومتلها بطريقة مفيدة ما. ستدير جميع البرامج التي كتبتها بشكل فعلي على الأقل بعض البيانات في الذاكرة . تخزن كل قيمة للبيانات في منطقة محددة ما 

من ذاكرة الكومبيوتر » على الرغم من أنها محددة بواسطة لغة التنفيذ المشتركة Language Ru {ine‏ onرصmmهc.‏ توجد العبارات في الفيجوال 
بيسك بشكل رئيسي لتدير و تعالج هذه البيانات بطرق معقدة و مفيدة . 

يتم تخزين كل البيانات المدارة بواسطة لغة التنفيذ المشتركة في ذاكرة الكمبيوتر » مع كل قيمة للبيانات منفصلة و محمية عن القيم الأخرى . وكأن لدى كل 
قيمة بيانات كوب شاي مستقل خاص بها كما يبدو في الشكل: 


N 
VAZ 
€ wEC ® CC © 


2 ر 2 


تمتلك جميع قيم البيانات المدارة بواسطة لغة التنفيذ المشتر كة محتوى ۸٤‏ ع1١٣‏ ٥ع‏ ونوع عمرئ. المحتوى هو البيانات الفعلية : السلسلة النصية ”,عطه“» 
العدد 5 » فاتورة بيع » شاي بيكو البرتقالي اللون . كل ما تضعه في كوب الشاي » وذلك هو المحتوى. في بعض الحالات › تسمح لك الدوت نت أن تخزن 
بدون شك لاشيء عاط هاا" في كوب الشاي (من أجل الأنواع المرجعية كما موصوفة باختصارء أو أنواع قيمة ملغاة أو باطلة) . 

يشير النوع إلى النوع المحتوى المخزن في كوب الشاي . في الشكل السابق » هذا معروض بواسطة الشكل لكل كوب شاي . لكل كوب شاي حدود على 
النوع من البيانات التي يمكن أن يتم سكبها في كوب الشاي : سلسلة نصية » عدد صحيح ما » فاتورة زبون ما . 


بعض قيم البيانات الأساسية »مثل الأعداد و السلاسل النصيةء يمكن إدخالها في كودك المصدري و استعمالها كما هي . على سبيل المثال » يعرض الإجراء 
×5980 1 نافذة برسالة نصية مدعومة . تتضمن العبارة : (42 "& " MsgBox)" he answer is‏ سلسلة محر في The " «/iteral sing‏ 

ئ¡ ٣‏ nsW0ه»‏ " و قيمة صحيحة محرفية » 42 . (الرمز "&" هو معامل يصل قيمتين مع بعضهما البعض في سلسلة حرفية جديدة .) تستخدم المحارف 
مرة » ومن تم تهلك . إذا أردت أن أعرض نفس الرسالة مرة أخرى ("42 كأ 8۲ ۷ه ٥طآ")‏ » علي أن أكتبها مرة ثانية بنفس قيم المحارف في جزء 
مختلف من الكود المصدري . 

تدعم الفيجوال بيسك أنو اع عديدة من المحارف الأساسية. تحاط المحارف النصية و/ھع)// وہ دائما بعلامات اقتباس ksاجة"‏ عامںو. إذا ردت 
أن تدخل علامة اقتباس ما لوحدها في المنتصف لنص ماء يتضمن علامتين بدلا من علامة واحدة : "This is "literally"" an example."‏ 
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يمكن أن تكون المحارف النصية كاعا6|اا ومأS‏ حقا » حقا طويلة »> تصل حتى حوالي 2 بليون حرف بالطول : إذا أردت أن تكتب حرف واحد فقط 
بكل ثانية » فإنه سوف يستغرق أكثر من 63 سنة ليصل إلى طول السلسلة الأعظمي . تتضمن الفيجوال بيسك أيضا المحارف الحرفية character‏ 
ا٣ا‏ التي هي بالضبط حرف واحد في الطول : إذا أردت أن تكتب حرف واحد فقط بكل ثانية » حسنا » لايهم . يتم تمييز هذه المحارف الحرفية بواسطة 
التذييل ”ء“بعد النص . يتم إدخال محرف الحرف ”۸“ كما : "۸"٥‏ 
يتم إحاطة محارف الوقت والتاريخ بإشارات عدد ك١‏ وای امطص نم بدلا من علامات الاقتباس . الوقت أو التاريخ (أو كلاهما) الذي تدخل يمكن أن يتم 
تمييزه في أي تنسيق من قبل الميكروسوفت ويندوز في منطقتك المحددة . إذا كنت مستخدما الفيجوال استديو Sud‏ اعuء۷‏ » فإنه سوف يعيد تنسيق 
تاريخك عندما تكتبه في المحرف :#7/4/1776# 
يكوّن أحد عشر نوعا مختلفا من قيم البيانات العددية - كل من القيم العددية الصحيحة و ذات النقطة العائمة ٤"أم-9"أاةه|؟-‏ جوهر ”0۴6ء“المجموعة 
من أكواب الشاي العددية. و من يحتاج إلى أكثر من 11؟ مع الأحد عشر كوب شاي تلك» يمكنك أن تدير الأعداد من الصفر بجميع الطرق إلى "1×10 
و ما بعد ذلك أيضا . ولتستخدم المحرف العددي» اكتب العدد على اليمين في كودك › مثل 27 ٠‏ أو 3.1415926535 . تتيح لك الفيجوال بيسك أيضا أن 
تحدد أي من الأحد عشر كوب شاي عددي تستخدم من أجل عدد ما » بإلحاق حرف خاص إلى نهاية العدد . وعادة 27 هو عدد صحيح 27 . ولتجعله بدقة 
العملة "عشري ”,اة"أعمل“"» مذيل بإشارة اه (@):@27 عندما أناقش أنواع البيانات بالتفصيل الكامل »> سوف أسجل في قائمة الحروف الخاصة 
المختلفة » مثل (@) › التي تدون نوع البيانات للأعداد الحرفية . النوع الرابع والأخير من محارف الفيجوال بيسك هو المحرف المنطقي ”اهم . 
تمثل القيم المنطقية النوع الأبسط من بيانات الكمبيوتر : : البت . القيم المنطقية هي إما صح أو خطأ » موصول أو مقطوع » نعم أو لاء لذيذ ey‏ 
قطط أو كلاب » صفر أو غير الصفر . يمتل المنطق 5ه ء|امم8 دائما أحد حالتين أو قيمتين متعاكستين . تمثل اللغة التي استخدمها العالم جورج بول 
الارات اوي و رياضیه . الكمبيوترات تحب م۷م/ الجبر المنطقي .لذلك جمیع العمليات الأساسية للكمبيوتر › مثل الجمع » يتم تنفيذها 
تتضمن الفيجوال بيسك المخارف المنطقية صح rue‏ أو خطأً هءاج ۴. لا يوجد علامات اقتباس » ولا إشارات أعداد » يوجد فقط الكلمات صح ٥م7/u‏ و 
خطاً عئ/ع. في حالات محددة » يمكنك معالجة الأعداد كقيم منطقية sمںاج۷‏ ٣جهامه8.‏ عليك أن تعرف الآن أن خطأ تعادل الصفر (0) › و صح 
تعادل کل شيء آخر (مع أنه بشكل عام »يستخدم -1 من أجل كل شي« Îخر “everything else”‏ (. 


جميع قيم البيانات المحرفية جيدة » ولكنها مفيدة مرة واحدة فقط » و بعدئذ ترحل .في كل مرة تريد أن تستخدم قيمة محرفية › عليك أن تعيد كتابتها .وكأن 
قيم البيانات مخزنة في الأكواب المعدة للطرح بعد الاستخدام بدلا من أكواب الشاي الصينية الجميلة . و بالإضافة إلى ذلك » يدخل المبرمجون فقط القيم 
الحرفية » وليس المستخدمين › لذلك فهي محدودة الاستخدام بالنسبة لبيانات المستخدم المدارة. 
ببساطة المتغير ات وم/ariab/‏ ليست أكواب معدة للطرح بعد الاستخدام : يمكن إعادة استخدامها . يمكنك المحافظة على وضع نفس النوع من الشاي مرة 
بعد مرة في كوب الشاي . كوب الشاي متغير نصي يمكنه أن يواصل سلسلة ما من أجل إعادة الاستخدام مرة بعد مرة . على سبيل المثال > في هذه القطعة 
من الكود ›» يستجيب المتغير للسلاسل المختلفة المسندة إليه : 
Dim response As String‏ 
response = "A"‏ 
MsgBox ("Give me an 'A'!")‏ 
MsgBox (response)‏ 
MsgBox ("Give me another 'A'!")‏ 
MsgBox (response)‏ 
MSsGBOX ( WHaE sS ENae Spell 2)‏ 
response = StrDup (2, "A")‏ 
MsgBox (response)‏ 
يتم إسناد المتغير response‏ مرتین بنصین مختلفين (کی السطر 1( وبعدئذ 7“ (في السطر 7( . إنه يحافظ على كل قيمة تم إسنادها إليه 
أخيرآ : يعرض كل من السطرين 3 و 5 ”^“ في نافذة صندوق رسالة ما . و ليس عليك أن تسند فقط النصوص المحرفية إليه (المتغير) : يمكن لاي شيء 
يولد النص أن يسند نتيجته للمتغير 56٣٠م5ه.‏ يستخدم السطر 7 دالة فيجوال بيسك جاهزة » م S۲0 u‏ « ليعيد سلسلة انحرفيj two-character‏ 
7“ و يسندها إلى المتغير م١٣همءم؟‏ .إن استخدام المتغيرات هو عملية ذات خطوتينمهأء-ه] . أولا عليك أن تصرح ۵6٥/۲٥‏ عن المتغير › 
و بعدئذ أن تسند ۸ و/ئىو قيمة ما إليه . تهتم العبارة "|0 بقسم التصريحات ١0ااة۲هاعمهك:‏ وهو يدعك تشير إلى كل من الاسم ٥/7و‏ النوع 
عمراللمتغير . وقواعده النحوية ×ه"لرء صريحة إلى حدما . 


Lae I CA en LOO ESS 


Dim response As String 
: 0م5ه مهو الاسم للمتغير و و" |أ٣)S هو نوعه . يحدث التصريح باستخدام عملية المساواة = كمايلي‎ ٣5٥ حيث‎ 
response = "The answer" 
يمكن أن يملك متغير مفرد قيم جديدة مسندة إليه بشكل متكرر . لهذه المرات عندما تريد لمتغيرك أن يملك قيمة محددة ما مباشرة حين التصريح › فإنه‎ 
: بإمكانك أن تدمج التصريح و الإسناد داخل عبارة منفردة‎ 
Dim response As String = "The answer" 
: بالطبع » إنك غير مقيد بتصريح مفرد فقط : يمكنك أين تنشئ متحولات عديدة كما تحتاج في كودك . ويستخدم عادة كل واحد عبارة "|01 الخاصة به‎ 
Dim question As String 
Dim answer As String 
: بإمكانك أيضا أن تجمع هذين المتحولين في عبارة وحيدة‎ 
Dim question As String, answer As String 
. 01" وهذه هي تماما البداية لما هو ممكن مع العبارة‎ 
Value Types and Reference Types ةمnيقلا الأنواع المرجعية و الأنواع ذات‎ 
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تخزن متغيرات النوع ذو القيمة قيمة فعلية ما: الشاي في كوب شاي نوع ذو قيمة هي المحتوى (المضمون) بذاته . جميع قيم البيانات Sa‏ 
ذكرتها سابقا » ما عدا النصية sSو١أ٣)؟‏ » هي أنو اع ذات قيمةوممر ماج۷ . تخزن متغيرات النو ع المرجعي "ءع مرا ۸٤٤٥‏ ٥٣٥م‏ "مرجع ما " 
أو إشارة إلى البيانات الفعلية » توجد البيانات في مكان ما آخر من الذاكرة . عندما تمعن النظر في كوب شاي قيمة مرجعية » عليك أن تعرف أوراق 
الشاي في الأسفل لتحدد المكان الذي تسكن فيه البيانات . إما تملك الأنواع المرجعية البيانات أو لا تملكها . في حال غياب البيانات » يأخذ نوع مرجعي ما 
القيمة لاشيء و٣‏ ااهل » وهي كلمة محجوزة ما للفيجوال بيسك والتي ڌ تشير إلى أنه لا بيانات . إن الأنواع ذات القيمة ليست لا شيء وہاNot:‏ :أبداً 
فهي تتضمن دائما بعض القيم > من المحتمل أن القيمة الافتراضية ان 6اك النوع (متل الصفر من أجل الأنواع العددية). يتیح لك نوع "بدون قيمة 
ماbوااuم"خاص‏ أن تسند لاشيء واه إلى نوع ما ذي قيمة › متيحا لك أن تنفد نفس المنطق " هل توجد أي بيانات هنا بأي حال من الأحوال " 


الذي يوجد 3 المرجعية . سوف أناقش الأنواع بدون قيمة عاطاھااںم لاحقاً. 


إن نوع البيانات النصية مفيد » و لكنه مجرد واحد من أشكال أكواب الشاي المتوفرة لديك . يعرف إطار عمل الدوت نت أنواع البيانات كعمر هdat‏ 
جوهرية متعددة. يتم تنفيذ كل نوع بيانات كفئة محددة ضمن فضاء اسم النظام "56ر6 . نوع البيانات الأساسية الأهم » كوب الشاي الكبير الذي يستطيع 
أن يملك أي نوع من البيانات » ويسمى بالكائن ا هزطا0. أكثر من مجرد كائن ماء فهذا كائن بحرف © كبير.في هرم فضاء أسماء مكتبة فئة الدوت نت › 
فإنه يُحدد في زا0 System.‏ وهواالام لج اللات أن لفوت تك وج 2© الاخ ى٠‏ وار كيب د و ات و الفر ات ١ ٠‏ بقل 
في أي مكان يسكن كل منها بالنسبة لهرم E‏ تمت كتابته من قبل الميكروسوفت أو من قبلك ءفهي مشتقة في النهاية من 
System.Object.‏ . ليس هناك ما يستوعبه : لايمكنك أن تنشئ نوع ما يشت يشتق بشكل أخير من أي شيء آخر . لذلك عد إلى أنواع البيانات تلك 
"الجوهرية"التي أشرت إليها سابقا . والتي تربط الأنواع الأربعة من قيم البيانات المحرفية التي جمعتها من قبل وهي : النصوص» التواريخ » الأعداد » و 
. ويصنف الجدول التالي أنواع البيانات الجوهرية تلك . يملك كل نوع أيضا اسم فيجوال بيسك محدد والذي يمكن (و يجب ) أن يستخدم بدلا 


Boolean Boolean‏ يدعم نوع البيانات المنطقية فقط قیم صح مں۲۲و خطأهوإه۴ . من الممكن أن تحول 
الأعداد إلى قيم منطقية : لذ نزغا ا آخر يصبح صح .وعندما تحول 
منطق ما بإعادته إلى عدد ءفإن خطأً يصبح 0 و صح يیصبح 1- . 


Char Char‏ يخزن نوع البيانات الحرفية 02۲ بالضبط حرف نصي واحد . تمثل كل قيمة 
بيانات حرفية 2 بايت (16 بت) من التخزين › لذلك يستطيع أن يدير مجموعة 
حروف ذات بايت مضاعف » مزودة الدعم للغات كاللغة اليابانية التي تملك عدد 
كبير من الحروف . على الرغم من أنه اعتاد أن يخزن حروف نصية مفردة » 
يحفظ نوع البيانات الحرفية الحروف كقيم عددية صحيحة » متراوحة من 0 إلئ 
5 وذلك بشکل داخلي. 


Decimal Decimal‏ يتم تصميم نوع البيانات إعص اعم بالاعتماد على العملة . إنها دقيقة جد في الحسابات 
الرياضية » ولها مجال جيد جدا » يدعم الأعداد التي هي بعد 79- الذي يتبع ب 27 صفر 
> الموجبة و السالبة»› (هل قلت 79- متبوع ب 27 صفر؟) وذلك طوله 29 رقم › و ذلك 
هام لتتذكرءنظرا لذلك حصلت على 29 رقم إجمالا على كلا جانبي من الفاصلة العشرية' 
يأتي العدد 79- المتبوع ب 27 صفر مع التقبيد بأنه لا أرقام إلى اليمين من الفاصلة 
العشرية . إذا أردت موقع عشري واحد › عليك أن تترك واحد إلى اليسار (الجزء 
العشري من اللوغاريتم ) و أن تبقي الأعداد إلى 9.7 المتبوع ب 27 صفر . إذا 
أردت 29 رقم بعد العدد العشري » لقد حصلت على صفر ضخم كبير من أجل 
اللوغاريتم . إذا كنت قد اعتدت أن تستخدم الفيجوال بيسك 6.0 ءالعدد العشري هو مشابه 
لنوع البيانات الثان ر يرc Curren‏ 


ا ي 


. إن نوع البيانات الصحيحة ۲ه وهام |هو 4 بايت (32 بت) نوع صحيح ذو إشارة‎ Int32 Integer 


4 


وهو يعالج الأعداد من 2,147,483,648- إلى 2,147,483,647 . إذا كنت مبرمج 
فيجوال بيسك سابق في الدوت نت ءفإن هذا نوع بيانات صحيحة جديدة مكافئ لنوع 
البيانات الصحيحة وonاذات‏ الإصدار 6.0 . 


الكائن هو نوع جوهري لجميع آنواع الدوت نت . وهو يأخذ مكانه عند قمة هرم النوع و 
الفئة: وهو الفئة الأساسية الجوهرية لجميع الفنات الأخرى. وهو نوع مرجعي » على 
الرغم من أن الأنواع ذات القيمة بشكل أخير تشتق منه › أيضاً . 


Object Object 


نوع البيانات القصيرة هم5 هو 2- بايت (16 - بت) نوع أعداد صحيحة ذات إشارة . 
وهو يخزن الأعداد من 32,768- إلى 32,767 إذا كنت مبرمج فيجوال بيسك سابق في 
الدوت نت » فإن نوع البيانات ١۲ممءالجديد‏ هذا مكافئ لنوع البيانات الصحيح 
ntegerاللاصدار‏ 6.0. 


نوع البيانات الحرفي هو نوع مرجعي و يصل تخزينه إلى حوالي 2 بليون حرف من 
النص. ويخزن حروف شبه الكود » التي تكون قدرتها 2- بايت (16- بت) لتخزين 
الحروف من معظم اللغات في العالم » المتضمنة لغات ذات أبجدية ضخمة › مثل اللغة 
الصينية . 


يخزن النوع الصحيح الطويل بدون إشارة وہہ ں8- بایت (64بايت) أعداد 
صحيحة بدون إشارة › متراوحة من 0 إلى 18,446,744,073,709,551,615 . 
وهو إصدار بدون إشارة لنوع البيانات الطويلة وها ذات الإشارة . 


UlInt64 ULong 


إن مطوري الميكروسوفت مسؤولون عن أنواع بيانات الفيجوال بيسك التي تنهي بشكل جيد تلك المهمة بما أن جميع أنواع بيانات الفيجوال بيسك الجوهرية 
هي ببساطة أغلفة من أجل أنواع بيانات محددة منفذة من قبل الدوت نت . أسماء الفيجوال بيسك المعطاة لكل من هذه أنواع البيانات الجوهرية هي بشكل 
كامل قابلة للتبادل مع أسماء الدوت نت . فعلى سبيل المثال » النوع الصحيح ۲٥و"‏ |مكافئ بشكل كامل للنظام الصحيح 32 .8S/56١١.|١32‏ في 
الحقيقة › عند كتابة كود الفيجوال بيسك » من الأفضل أن تستخدم مرادفات الفيجوال بيسك » بما أن معظم مطوري الفيجوال بيسك يتوقعون أسماء نوع 
البيانات هذه ة في الكود الذي قرؤوه وكتبوه . 

ماعدا الكائن sObject‏ النص و S٣٣‏ › جميع أنواع البيانات هذه هي أنواع ذات قيمة . تشتق جميع الأنواع ذات القيمة System.Value Type ja‏ 
(الذي بدوره يشتق من أ عزا0.١٠ء/5)‏ . البايت ذو الإشارة 6ر58 » الصحييح بدون إشارة 6۲و" |ل » الصحيح القصير بدون إشارة 
Short‏ الصحيح الطويل بدون إشارة وه ال » وأنواع بيانات تم إضافتها إلى الفيجوال بيسك مع الإصدار 2005 » على الرغم من أن مكافئات 
فضاء أسماء النظام "ءل الخاص بها هي في الدوت نت منذ بدايته. على خلاف أنواع البيانات الجوهرية الأخرى » فإن هذه الأنواع الأربع ليست 
"خاضعة لتوصيف اللغة المشتركة†١هاام"0ء-15©‏ ". وهذا يعني أنه» لا يمكن استخدامها لتتفاعل مع عناصر الدوت نت و اللغات التي تعرف نفسها 
بأنها ميزات الدوت نت الجوهرية فقط المطلوبة كثيراً . على العموم هذا التقييد ليس بالكثير » ولكن كن على حذر عند العمل مع مكونات أو لغات ثانوية. 


e 


عندما ذكرت الحاجة إلى تصریح dec/aArAt0‏ و إسناد المتحولات › کنت أركز فعلاً على الأنواع ذات القيمة . تتطلب الأنواع المرجعية خطوة إضافية 


واحدة : وهي الاستنساخ 1/81/0۸ 1ء”/.إليك عبارات التصريح التالية : 
Dim defaultValue As Integer‏ 
Dim nonDefaultValue As Integer = 5‏ 
Dim defaultReference As Object‏ 
توضح هذه السطور ثلاث متحولات منفصلة : اثنان من الأنواع ذات القيمة (النوع الصحيحك۲هوع],| )و النوع المرجعي (الکائن)ecزOb‏ ). على الرغم 
من أن متحول واحد فقط يملك إسناد بیانات صریح »فان > جميع المتحولات الثلاث السابقة تم إسنادها بالفعل لشيء ماء إما بشكل صريح أو ضمني . لننظر 
إلى هذه العبارات مرة أخرى و نرى ما تم إسناده بشكل صحيح إلى المتغير. 
Dim defaultValue As Integer = 0‏ 
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Dim nonDefaultValue As Integer = 5‏ 
Dim defaultReference As Object = Nothing‏ 
حدث کل من التصريح والإسناد مسبقا لجميع المتحولات » وذلك فقط باستخدام العبارة "01 . المتغير عمںاج۷اهfمل‏ » مع إسناده الافتراضي إلى 
الصفرء يمكن أن يستخدم مباشرة في معادلات . على أية حال »إن متحول النوع المرجعي ۸٥6۲6٣٥۵٥‏ العمل هو کوب شاي فارغ تماما »› مع 
بیانات غیر افتراضية لتتم معالجتها . يوجد ميزات في الفيجوال بيسك والتي تسمح لك أن تقارن الأنواع المرجعية مع لاشيء Nothing‏ > ويمكنك أن 
تفعل هذا مباشرة › ولكنها بالواقع ليست بيانات .و تذكر » إن المتغيرات تعيش لتدير البيانات . 
تحتاج قیم الأنواع المرجعية للاستنساخ ¢ ويحتاج لقاع اكلا سحجرزة جديدة :New‏ 
Dim defaultReference As Object = New Object‏ 
تشير الآن ٠٠۲٠۸٥٥‏ 1۸ا ممه إلى كائن حقيقي : يملك الآن كوب شاي ٥٥۲٠۸٤٥٥‏ ۸ لاجمل شيء ما قابل للاستهلاك داخله »> ورغم من أنه مجرد 
System. bjet‏ » فهو لا يملك الكثير في الطرق. النصوص هامة أكثر بقليل » وتملك أيضا المشيدات الهامة. 
المشيد هو مقطع من كود التمهيد ١٥0اهااهزاأما‏ الذي ينفذ عندما تنشئ كائن أو نوع بيانات جديد . تسمح لك بعض الكائنات بأن تمرر معلومات إضافية 
إلى مشيد ماءوالمعلومات الإضافية التي تم استخدامها في المعالجة التمهيدية . لاإيسمح لك المشيد الافتر اضي/ه0اع ١۸5٥ء‏ االاة/۵6 بتوفير أية 
معلومات إضافية : إنه يعمل بنفسه فقط مسندآً قيم أولية للبيانات بدون تدخل خارجي . لا يوجد حدود لعدد المشيدات في الفئة » ولكن يجب على كل واحد 
أن ينوع في نوع المعلومات الإضافية الممررة إليه . لذلك فبالعودة إلى السلاسل الحرفية sو”آ)S.‏ يعمل المشيد الافتراضي للسلسة الحرفية ببساطة على 
إنشاء لوح فارغ )هاط » أو سلسلة حرفية ذات طول صفري ۸اوہ اه٣z6:‏ 
DIM WOEICOSMOS EBOEINSSEEIDNS AS SEIN NEN SEEING‏ 
الآنء لا أحد يعمل هذا » بما أن العبارة التالية تعمل بشكل جيد تماما ٠‏ 
DAM WORE IOSMOSE BOSE TOS ADS AS OEE O >‏ 
وذلك لأن السلاسل الحرفية كو |آ٣)تتم‏ معالجتها بشكل خاص من قبل الفييجوال بيسك . إن المحارف النصية كاج6۲)أا وأ٣)5عمليا‏ هي استنساخات 
من قيم البيانات النصية و٠1ء5:‏ وكأنك أنشأت حالة (نسخة) نصية و أ٣)5‏ جديدة باستخدام فة و١أ٣)5."ءرك.‏ ذلك صحيح على الأقل عند استخدام 
المشيد الافتراضي لأنواع البيانات النصية . ولكن تملك السلاسل الحرفية مشيدات هامة أكثر . ( سأبحث في تفاصيل المشيدات في الفصل التامن ) . يعمل 
واحد من المشيدات على إنشاء حالة (نسخة ) سلسلة نصية جديدة ممهدة بحروف خاصة مكررة عدد من المرات . 
على سبيل المثال » لإنشاء حالة نصية جديدة بسلسلة حرفية ذات 25 حرف من الحرف / . استخدم البناء التالي : 
DIM MREOOM AS SEEN MEW SEEING (IM CF, 25)‏ 
إذا كنت ستستخدم نفس نوع البيانات فقط بعد الكلمة المحجوزة ك۸ بحيث تستخدم بعدها مباشرة الكلمة المحجوزة "٠W‏ وبالتالي فإنك تستطيع 
استخدام التركيب المختصر(أو المطوي) كمايلي : 


كما مع الأنواع ذات القيمة › يمكنك تقسيم العبارة إلى عبارة تصريح واضحة وعبارة إسناد : 


Dim mmEeEood AS Nev SEEING (CME, 25) 


Dim mmEeood AS SERIN 
mMMEOOd = New String (MIC, 25) 


لا تتغير المحارف » ولكنك تستطيع أن تستخدمها مرة فقط في كودك .إن الثوابت كأ" هائ” ٥‏ هي المعبر بين المحارف و المتغيرات : ولديها قيمة 
مفردة غير قابلة للتغيير وأو مجاء-۲ه۷هم تماما مثل محارف البيانات » ولديها أيضا اسم يمكنك أن تستخدمه بشكل متكرر» تماما مثل المتحولات . 
صرح عن الثوابت مستخدما الكلمة المحجوزة ورمع بدلا من الكلمة المحجوزة "أ0 : 

Const SpeedOfLight As Integer = 186000‏ 
يحدث الإسناد الفعلي للقيمة إلى الثابت في العبارة نفسها » مع القيمة التي تتبع المعامل = . حالما يتم التصريح والإسناد للثابت ءفإنه يصبح متاح للاستخدام 
في عبارات فعلية من كودك الفعلي : 


MsgBox ("Lightspeed in miles/second: " & SpeedOfLight) 


في العالم الحقيقي » تحتاج لأن تحفظ بعض كخاصة » من أجل استخدامك فقط . ولكن توجد معلومات عامة ليست مخبأة عن أي شخص . وهذه الطريقة 
ليست فقط في العالم الواقعي : يملك العالم الزائف للفيجوال بيسك مستويات مختلفة من الوصول والخصوصية (السرية]) لبياناتك . بعد قليل سوف نرى أن 
كود منطق تطبيقك سيظهر دائما في إجراء »> مسمى مقطع الكود المصدري . إنك تصرح عن متحو لات محلیۃوم/ /oca/ vari‏ (و ثوابت 
5 حع) في نفس هذه الإجرائيات عندما تحتاج إلى متغير شخصي وقصير العمر ل ع۷ ااه طءرذلك فقط من أجل الاستخدام ضمن الإجراء 
الواحد . يمكن أن تظهر المتحولات الأخرى (و الثوابت) خارج الإجراء »و لكن يبقى ضمن سياق فئة ما أو نوع مشابه . وهذه الحقول وال/عت/ »أي كانت 
متغيرات أو ثوابت » هي متاحة مباشرة لجميع الإجراءات المختلفة والتي ت تستدعي أيضا الفئة الحالية. 
إنك تعرف جميع المتحولات المحلية مستخدما الكلمة المحجرزة 0i"‏ . تعمل العبارة ص من أجل تعريفات الحقول » ولكن من الشائع أكثر استخدام 
كلمات محجوزة لمحددات وصول خاصة بدلا منها . و تحدد هذه المعدلات(أو المحددات) أي كود يستطيع الوصول إلى الحقول » من ۴|۷٥‏ (مستخدما 
فقط من قبل الكود داخل الفئة ) إلى عiاطں‏ ۴ (أيضا متغير خارج الفئة ) : 

Private ForInClassUseOnly As Integer 
توجد خمس محددات وصول. سوف أناقشها أكثر وأناقش الحقول بشكل عام في الفصل السادس.‎ 


إن اللغة الأجنبية في هذا الكتاب هي الفيجوال بيسك » واللغة الإنكليزية هي اللغة العامية » يمكنك أن تجد مقطع خاص من كود الفيجوال بيسك تمت كتابته 
على نحو رديء أو حتی مكروه › ولکن إذا كانت التعليقات المصاحبة مضبوطة (دقيقة ) » مع اللغة البشرية موaمuوهةا-٣‏ 2" نم المفهومة للمعالجة . 
تظهر التعليقات ءأ٣ ٥۳١"6‏ عادة على السطور بحد ذاتها » ولكنك تستطيع أيضا تلحق تعليق إلى نهاية سطر الكود الموجود . إذا تم قطع سطر منطقي 
ما إلى سطور حقيقية متعددة باستخدام حرف متابعة السطر "" » فإن تعليق مذيل يكون قاطعا عند نهاية السطر الحقيقي النهائي : 
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١ سس‎ THIS 1S a SEaNda lone COMNeNME, OM a line Oy TESeLE. 
Dim Counter AS Integer | TIS 18 @d EFallINS COMMON. 
MSEC ThE ECSU ESE SEAR ES dE GCG E OLAS COMME EBEE 
EOURNESEE) 1 BU kCals One 1S valid. 
تبدأ التعليقات مع حرف التعليق » حرف علامة الاقتباس المفرد القياسي ('). أي نص متبوع بحرف التعليق هو تعليق » و يتم تجاهله عندما يتم ترجمة‎ 
. الكود داخل التطبيق القابل للاستخدام . يظهر أي مقطع وحيد ضمن نص محرفي لم يتم استخدامه كعلامة تعليق‎ 
MSITEOX (INS Eeommenées In ENIS Ee.) 


يمكن أيضا أن تنشأ التعليقات بالكلمة المحجوزة R٤۷‏ ( كما في ۸٤18۲)"‏ ")ء ولكن يستخدم معظم المبرمجين العلامات المفردة بدلا منها . 


بعض أمثلة الكود التي رأيتها سابقا والتي يدعمها الفيجوال بيسك بقيمة إسناد افتراضية ۸٣٠"٠"‏ اكه االاههل لمتغير ما على الأقل من أجل الأنواع 
ذات القيمة - إذا أهملت تضمين واحد . في حالات محددة » سوف يدعم الفيجوال بيسك أيضا التصريحات 0۸او/4/٥ ۵/٥‏ إذا تركتها خارجا . في العبارة : 
lorem ONENVEL ue = 5‏ 
إذا لم يكن هناك عبارة ة "01 والتي تعرف مuاة۷‏ س٥ل‏ 4معاط » فإن الفيجوال بيسك سوف يصرح عن المتغير بالنيابة عنك » مسندا إياه إلى نوع 
البيانات ٤‏ هزطا0. لا تدع هذا يحدث لك ! فإنك لا تعرف أي نوع من المشاكل ستحصل إذا سمحت لمثل هذه الممارسات في كودك . سوف تجد بسرعة أن 
كودك مملوء بالعلل المنطقية الغامضة › ونتائج بيانات خفية » وهكذا , 
المشكلة هي أن الفيجوال بيسك لن يحتچ(يشتکي) إذا أخطأت بكتابة الاسم لمتغيرك المصرح عنه ذاتیا ٣٥٩0‏ aاcمل-ە{uه»ءالمتروك‏ بدون اختبار › مثل هذه 
الممارسات يمكن أن تؤدي إلى كود متل هذا : 
BEandNe wMa lue > ©‏ 
MsgBox (brandNewVlaue‏ 
يترجم فيجوال بيسك العبارة بدون أي أخطاء ؟ و الآن يعرض صندوق الرسالة لاشيء بدلا من الرقم 5 ؟ بإمكانك أن تتجنب مثل هذه الصدمة بحكمة 
کک العبارات pti‏ الداخلة في لغة الفیجوال بيسك . ويوجد أربع أنواع لهذه العبارات : 
ترك ا هذه العبارة أن تصرح عن جميع المتغيرات مستخدما "01 (أو عبارة مشابهة ) قبل الاستخدام . من الممكن أن تستبدل مكان ”0۸“ ب ۴©“ في 
العبارة ¢ ولکن لا تفعل هذا . 
هه خيار التدقية 
سوف تعمل ا ا البسيطة من أجلك عند الحاجة . على سبيل المثال »إذا أسندت قيمة بيانات طويلة و ٣0ا‏ 64 - بت 
لمتغير صحیح 32Integer‏ - بت »عندئد سوف تحول الفيجوال بيست بشکل عادي هذه البيانات الف حجم أصغر » محتجه فقط إذا لم تتلاءم البيانات. هذا 
النوع من التحويل - تحويل تضيق - ليس آمنا بما أن البيانات المصدرية سوف تفشل أحيانا لتتناسب في المكان المحدد . 
(تحويل التوسيع »> کما مع تخزين البيانات الصحيحة ntegerافي‏ الصحيح الطويل Long‏ < > تعمل دائما » بما أن المكان المحدد دائما يحجز القيمة 
المصدرية .( إن عبارة خيار التدقب Option Strict ON Jı‏ تتخلص من المعالجة الذاتية لتحويلات التضييق . و يتم إجبارك على أن تستخدم دوال 
التصريح أا لتنجز تحويلات التضييق . وهذا جيد » بما أنها أجبرتك أن تفكر حول نوع البيانات لمتغيراتك التي حجزتها . يمكنك أن تستبدل 
7“ ب 0۴6“ في هذه العبارة » ولكن إذا حذرتك مرة فإنني أحذرك مرتين :بأن لاتعمل هذا . 
۵ خیار الاستنتاج 
تخبر عبارة الفيجوال بيسك 2008 ا ری اک نی ن ی د و یات کی کی ی کرو أن يستخدمها خاصة عندما لا تخبره . 
سأناقش خيار الاستنتاج في الفصل السادس » لذلك سوف أؤخر التفاصيل الآن . عادة هذا الخيار فعال ” “On.‏ 
© خیارا المقارنة الثنائي والنصي 
يوجه هذان التشكيلين من عبارة خيار المقارنة eإaم"0۳ع٥‏ ۸٥أام0‏ كودك ليستخدم قواعد الفرز الخاصة من ا ميزات مقارنة سلسلة نصية محددة . 
على العموم » المقارنات الثنائية رة" 8 هي حساسة لحالة الحروف ع۷أاأوئممء-هءهء » حيث أن المقارنات النصية ٣٠×‏ ليست كذلك . يعود الأمر 
إليك في أي طريقة تريد أن تستخدم :القيمة الافتراضية هي الثنائية . تظهر هذه العبارات عند أعلى كل ملف كود مصدري في مشروعك » قبل أي كود 
اخر : 
OPE HOD Expl en E OD‏ 
OB ETON SERIE E OM‏ 
أو لتوفير سعة على قرصك الثمين »هناك القيم الافتراضية التي تقدمها لكامل مشروعك من خلال خصائص المشروع . في الفيجوال استديو › اختر القائمة 
مشرو ع اcمزPro‏ ثم أمر الخصائص ءام مه۴. ثم على نافذة خصائص المشروع التي تظهر »› اختر تبويب ماام "ه٥‏ و هيئ الاختيارات 
الافتراضية من أجل الخيارات التالية : 
“Option compare» “Option strict,”« “Option explicit‏ »و infer”‏ tinم0“‏ (انظر الشکل التالي): 


الفصل الثاني:تقديم الفيجوال بيسك. Mhm76‏ 


û pplication 
Build output path: 


Lampile binReleaşe | ElBaze", binifeleasek || Browse... | 


Lompile Uptionz: 


Debug 

Uption explicit: Uptior strict: 
ف‎ 
Resources Upton compare: Upton infer: 


Binay ا‎ 
Services : : 


تتضمن الفيجوال بيسك عمليات أساسية عديدة و التي تدعك تعمل ما يريد أن يفعله كودك فعلاً : معالجة البيانات . تتيح لك معاملات الفيجوال بيسك أن 
تنجز ال إدارة رياضية » منطقية »عددية ثنائية » ونصية » وجميعها بدون كلفة إضافية. 
الفعامل الأسانى هو مخامل الإستاد » ممثل بواسظة إشارة المساراة () .لق رايت مسقا هذا المعامل في هذا الشم , استخمه لفن جن اقيم إلى 
متغير ما ( أو ثابت) : يتم إسناد كل ما يظهر على يمين المعامل إلى متغير النوع المرجعي أو النوع ذي القيمة الذي على اليسار. العبارة : 

fiveSquared = 25 

هي إسناد قيمة 25 إلى المتغير ل١eإم5»uما؟‏ . معظم المعاملات هي معاملات ثذائية ء/ماه/هممه 6/8/۷ - وهي تعمل على قيمتين متميزتين › واحدة 
على يسار المعامل و واحدة إلى اليمين : النتيجة هي قيمة محسوبة وحيدة .وكما مع الحسابات يتم استبدالها بشكل كامل بالنتيجة المحسوبة . على سبيل 
المتال ¢ عملية الجمع 


1 


seven 4 € 4 


ا 


seven = 7‏ 
قبل التطبيق النهائي لمعامل الإسناد (=( . يظهر المعامل الفردي unary operator‏ إلى اليسار فقط من معامله . على سبيل المتال » معامل النفي 
الأحادي يحول العدد الموجب إلى عدد سالب : 
negqativeSeven = -7‏ 
يضع الجدول التالي قائمة معاملات الفيجوال بيسك الرئيسية و يصف باختصار الغرض من كل واحدة . 
EEN‏ 


E 


+ 


يحفظ معامل الزائد الفردي الإشارة لقيمة عدد ما . وهو ليس مفيد جد لكي تحصل على معامل تحميل زائد 


يعكس معامل النفي الفردي الإشارة لعامله العددي المقرون به 


يقسم معامل القسمة العامل العددي الأول بواسطة الثاني » مرجعا ناتج القسمة المتضمنة أي باقي عشري. 


کک 


© 


Mo 


go 


EERE EEE EEE EES ESE EEE ES 


يشبه هذا المعامل تماما معامل And‏ < و لکنه لا يفحص أو يعالج العامل الثاني إذا کان الأول False EA‏ . 


> 
5 
a 
> 
2 
° 


يشبه هذا المعامل تماما معامل ‘Or‏ ولکنه ل يفحص أو يعالج العامل الثاني إذا کان العامل الأول صح „True‏ 


O 
8 
1 
n 
® 


يعود معامل"أو" الخاص بالقيمة صح True‏ کان واحد وواحد فقط من العوامل صح „True‏ 


يرفع معامل الرفع الأيمن البتات المستقلة في معامل عددي صحيح ما إلى اليمين باستخدام عدد مواقع البتات في العامل الثاني . 


يعود معامل المقارنة أقل من ۸ج٣‏ ا-ووم| القيمة صح مں۲! إذا كان العامل الأول أقل من ”"۸2] ووم|“ الثاني . 
يعود معامل المقارنة أكبر من ۸هم٤-هاهموالقيمة‏ صح مں٣۲إذا‏ كان العامل الأول أكبر من الثاني ”ہ۸2 وهاو“ . 


يعود معامل المقارنة لا يساوي إلى 0ا-امuوه-اهمالقيمة‏ صح مں٣إذا‏ كان العامل الأول لا يساوي إلى الثاني 7ه اوم هم“ 


يعود معامل مقارنة كائن يساوي إلى القيمة صح إذا كان كلا العاملين يمتلان نفس الحالة لنوع بيانات ما في الذاكرة . 


الفصل الثاني:تقديم الفيجوال بيسك. Mhm76‏ 


وضع العامل الثاني إلى القيمة لاشيء و امه تدعك تختبر المتغير المرجعي لترى فيما إذا يحتوي البيانات أم لا . 


بقدر فعالية المعاملات»فهي تستحوذ على فعالية أكبر عندما تعمل على دمجها.وهذا يعمل لأن أيا من العوامل يمكن أن تكون تعابير معقدة بحيث تتضمن 
عوامل خاصة بها.الأقواس المضمنة حول شروط في عامل تضمن معالجة القيم في الترتيب الذي تتوقعه. 

CGMECIEAFeA pil < (EaAdIUS € 2)‏ 
في هذه العبارة » العامل الثاني لمعامل الضرب * هو تعبير آخر » و الذي يتضمن المعامل الخاص به . 


تسمح لك اللغات الإجرائية أن تقسم كودك داخل ما يسمى مقطع منطقي » تدعى الإجراءات . تتيح هذه الإجراءات " التقسيم و التحكم " بالوصول إلى 
المحاكاة البرمجة: وأنت تكتب الإجراءات التي تنجز قسم منطقي محدد من الكود ضمن تطبيقك الكامل › و بعدئذ الوصول إلى هذه الإجراءات من 
الإجراءات الأخرى . تتضمن الفيجوال بيسك مو8 اهدءا۷ ثلاثة أنواع من الإجراءات وهي: 
الروتينات الفر عي Subroutines‏ 
هذه الإجراءات » تدعى أيضا الإجراءات الفر عية ومu‏ ١ءء‏ ه/ مى » اعمل إجراء جزئي و بعدئذ عد إلى استدعاء الإجراء . يمكن أن يتم إرسال 
البيانات إلى داخل الإجراء الجزئي من خلال قائمة المعاملات النسبية ءا ۲ع ”وج . و يمكن أن تعود بعض القيم من خلال نفس تلك القائمة »› 
ولكن لا يرسل الإجراء نتيجة نهائية رسمية للخلف . يعمل الإجراء الجزئي عمله » وحالما يكتمل » يستمر استدعاء الكود على طريقته النشيطة . 
Functions Jll e‏ 1 
تشبه الدوال الإجراءات الجزئية تماما » مع ميزة إضافية واحدة : وهي أنك تستطيع أن تعيد قيمة وحيدة أو حالة كائن من الدالة كنتيجته الرسمية . 
وبالعادة » يأخذ الاستدعاء هذه القيمة الراجعة بعين الاعتبار عندما يكتمل منطقه الخاص. 
lلخاصيlٽ Properties‏ 
عندما استعملت ٬الخاصيات‏ والتي فعلا تبدو كالمتغيرات . أسندت و استرجعت قيما إلى و من الخاصيات تماما كما عملت مع المتغيرات . على أية 
حال » تتضمن الخاصيات الكود المخفي » و المستخدم غالبا لتثبيت البيانات كونها مسندة إلى الخاصية . 
الإجراءات الفرعية و الدوال و الخاصيات هي أعضاء الكود لكل فئة أو نوع مشابه . سوف أؤخر نقاش الخاصيات قليلاً فيما بعد في القسم . أما الآنء دعنا 
نستمتع بالدوال و الإجراءات › اللذان يعرفان مع بعضهما البعض بالطرق ds‏ زام"/. ولنبداً بالإجراءات الفرعية . لکي تستدعي إجراء فرعي ماء اكتب 
اسمه كجملة » متبو عة بمجموعة قوسين . أي بيانات تحتاج لكي ترسلها إلى الإجراء تذهب في الأقواس على سبيل المثال > يعمل استدعاء الإجراء 
الفرعي التالي بعض العمل » ممررا العدد 0 |للزبون »و هام10إهاء: 
DoSomeWork (customerID, startDate)‏ 
يعرف كل إجراء فرعي نوع البيانات و ترتيب المعاملات النسبية التي ممررتها . تضع هذه المعاملات النسبية قائمة يمكن أن تتضمن واحد أو أكثر من 
المعاملات النسبية الاختيار ية ىام uو/ةج‏ اج”م/امه › التي يتم إسنادها إلى القيم الافتراضية إذا لم تتضمنها . من الممكن أن يكون الإجراء الفرعي معاد 
تعر يفه 0ع 0وه//۷6٥.‏ ومعرفاً قوائم معاملات نسبية ممكنة مختلفة مبنية على العدد ونوع بيانات المعاملات النسبية . سوف نصادف الكثير من هذه فيما 
بعل 
الدوال أكثر متعة قليلاً بما أنها تعيد القيمة القابلة للاستخدام . وغالبا » يتم إسناد هذه القيمة إلى متغير ما : 
Dim balanceDue As Boolean‏ 
balanceDue = HasOutstandingBalance (customerID)‏ 
وبعدئذ باستطاعتك عمل شيء ما بهذه النتيجة . إذا أردت » يمكنك أن تتجاهل القيمة العائدة لدالة ما » و تكون لدينا مسبقا . تعيد الدالة المستعملة باكراً 
MsgBox‏ المطابقة من زر منقور على الشاشة on-screen‏ من قبل المستخدم لإغلاق صندوق الرسالة .إذا ضمنت فقط الكلمة 0في الزر (القيمة 
الافتراضية)» فمن المحتمل أنك لا تهتم بأي زر ينقر المستخدم . 
MSGEOX (IGS ahead, Click the OK BUEEODN 1)‏ 
ولكن بإمكانك أيضا أن تتحكم بالنتيجة من الزر : 
MOALMEREUL EON  MSIBOX( Cliek Yes OE NO , WMSGBOXSEVle. eSNG)‏ 
في هذه الحالة › whichButon‏ سوف يكون إا Msg BoxResult.Yes‏ أو t.NoاBoxResuوNs‏ » لقد تم تعريف النتيجتين الممكنتين من قبل الدالة 
.MsgBox‏ 
llشروط Conditions‏ 
في بعض الأوقات يتوجب عليك أن تصنع بعض الاختيارات » و سوف تساعدك التعابير الشرطية أن تعمل ذلك تماما . تتضمن الفيجوال بيسك دعما 
للشروط » التي تستخدم اختبارات البيانات لتحدد الكود التالي الذي يجب أن تتم معالجته . 
عبارات الشرط | 
العبارة الشرطية الأكثر شيوعا هى عبارة ۴| . وهى مكافئة للأسئلة الإنكليزية فى الصيغة " إذا كان كذا و كذا صحيحا › عندئذ نفذ كذا و كذا . " على سبيل 
المثال » يمكنها أن تعالج " إذا كان لديك $20 › عندئذ يمكنك أن تشتري لي طعام الغداء » " تملك عبارة ۴| قواعد لغوية والتي تقيس تعدد سطور الكود 
المصدري 


0 IF (hadAHammer = True) Then 

22 DoHammer (inTheMorning, allOverThisLand) 
3 DoHammer (inTheEvening, allOverThisLand) 
4: Elself (hadAShovel = True) Then 

5 DoShovel (inTheNoontime, allOverThisLand) 
o8 Else 

7 TakeNap (allDayLong, onMySofa) 

ل 0 
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تتيح لك عبارة ۴| تعريف التفرعات في كودك المبني على الشروط . إنه يبنى من ثلاثة عناصر رئيسية :وهي . 
Conditions طgرشll e‏ : 
إن التعبير الموجود بين الكلمة ۴| ( أو ۴اهءاع) و الكلمة المحجوزة ۲"٠"‏ هو الشرط . يتضمن الاختبار شرطين » على السطرين 1 و 4 . ومن 
الممكن أن تكون الشروط بسيطة أو معقدة » ولكن يجب أن تنتج دائما بقيم منطقية ۵۸٥ا8oo‏ صحیحة مں٣]‏ أو خاطئة مءام۴.و يمكن تتضمن 
استدعاءات لدوال أخرى و معاملات مقارنة و منطقية متعددة . 
li ((BIEMSESONTEM (MONETTE) 2= O) AMI (BLAVELEORTEEM(TESITINGTEN) 2> YY CO |‏ 
(justPracticing = True) Then‏ 
Blayeal iy‏ 
Else‏ 
SE AGI AUS S (EE ORE E)‏ 
NOL J‏ 


يتبع الشرط الأصلي دائ الكلمة المحجوزة ۴|. إذا فشلت تلك الشروطء تستطيع أن تحدد شروط إضافية تتبع الكلمة المحجوزة ؟|مءإع» كما على السطر 4 . 
يمكنك أن تکتب عدد من عبارات ؟اهءاع كما تحتاج . لا يتيح لك الشرط الاختياري هماع أن تحدد تعبير اختبار ما. بدلا من ذلك» إنه يصل كل شيء لم 
يتم ضبطه بعد بواسطة عبارات ۴| أو ۴اهءاع. يتم السماح بعبارة هءإعواحدة فقط لكل عبارة ۴| . 
تفر عات Branches‏ + 
تكون كل كلمة شرط محجوزة 76 متبوعة بواحد أو أكثر من عبارات الفيجوال بيسك التي يتم معالجتها إذا تم تقييم الشروط المرافقة إلى صح 
مں٣آ.‏ جمیع العبارات حتی تصل إلى مواع؛ ۴امءاع »أو ۴| كمع التالية تكون مضمنة في مقطع عبارة التفرع(أي تتم معالجتها حتى تصل إلى التفرع 
التالي) . يمكنك أن تضمن أي عدد من العبارات في قطعة تفرع ما » وحتى عبارات ۴| ثانوية إضافية . في الكود البسيط تتم معالجة سطور التفرع 
2 و 3 إذا كان الشرط الأصلي ۲٠ص"‏ ه١4۸ه"‏ صحيحا . تتم معالجة السطر 5 بدلا من ذلك إذا سقط الشرط الأصلي » ولكن إذا ما مر الشرط 
الثاني ۷٥۵4ھ‏ .إذا لم يكن أي من الشروط صحیحا مں٣۲ ٠‏ فإن تفرع ماع » على السطر 7 ٠‏ ينفذ . 
الكلمات الndحجوjة ‘Statement keywo/ds‏ 
إن عبارة ۴إهي واحدة من العديد من عبارات الفيجوال بيسك المتعددة الأسطر »› وجميعها تنتهي بالكلمة المحجوزة همع متبوعة باسم الكلمة 
المحجوزة الأصلية ( ۴| في هذه الحالة ) . تتضمن الكلمات المحجوزة لعبارة ۴|ء والتي تمنح العبارة ترك : End If y« Else« Elself « Then « If‏ 
. إن جميع عبارات ماعو ۴امءاع والفروع ذات العلاقة هي اختيارية . تتضمن عبارة ۴| الأبسط تفرع ۴| فقط. 
Tf (phoneNumberLength = 10) Then‏ 
DialNumber (phoneNumber)‏ 
MG‏ 
من أجل الشروط ذات التفرعات وبعبارة مفردة بسيطة وبدون شروط ؟امء|ع »فسطر واحد بديل يمكن أن يحفظ كودك أوضح. 
If (SaveData() = True) Then MsgBox ("Data saved.")‏ 


If (TimeOfDay >= #1:00:00 PM#F) Then currentStatus = WorkStatus.GoHome Else currentStatus = 
WorkStatus. BusyWorking 


إن عبارات ۴| جامدة لأنها تجعل كودك أكثر من مجرد تعليمات مجموعة خطية مملة تدريجيا والتي تنحرف لأي سبب . تتم كتابة البرمجيات لتدعم بعض 
عمليات العالم الحقيقي . و عمليات العالم الحقيقي نادراً ما تكون خطية . تجعل عبارة ۴| إمكانية كودك ليستجيب إلى مختلف شروط البيانات » آخذا التفرع 
المناسب عند الضرورة . 

حالما تدخل ۴| ۴...٤ "١‏ تكتمل القطعة » وتستمر المعالجة بالعبارات التالية التي تلي العبارة ۴| ۴۵. 


بعض الأحيان من المحتمل أن تكتب عبارة ۴| والتي تختبر متغير على قيمة محتملة وحيدة»مع ٣٥ط‏ أخرىءو ۸٥ا‏ » و ”عطtءوهكذا:‏ 
IE (oaLlIvalue = 1) Tan‏ 


presidentName = "Washington" 
Elself (billVvalue = 2) Then 

presidentName = "Jefferson" 
Elself (billValue = 5) Then 

presidentName = "Lincoln" 


وعليه تذهب » خلال عبارات إامءاع كثيرة متعددة . إنها فعالة » ولكن مملة قليلا » كما أن على كودك أن يختبر بشكل خاص كل حالة . تدعم عبارة اختر 
حالة موه ع هام5 بديل أوضح من أجل مقارنات قيمة بسيطة على قائمة ما : 


2 Select Case billValue 

02 Case 1 

3 presidentName = "Washington" 
4: Case 2 

5 presidentName = "Jefferson" 
8 Case 5 

E presidentName = "Lincoln" 

0 Case 20 

98 presidentName = "Jackson" 
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10E Case 50 

11: presidentName = "Grant" 

28 Case 10, 100 

9 presidentName = "!! Non-president" 
14: Case IS > 00 

15 presidentName = "!! Value too large" 
1 Cas€ê Else 

0: presidentName = "!! Invalid value" 
12 End Select 


على خلاف عبارة ۴|ء التي تعمل اختبار من أجل نتيجة منطقية ما ءتقارن مه اءه|م5 قيمة مفردة مع مجموعة ما من قيم حالة اختبار ما . في المثال »› 
تتم مقارنة المتغير ga billValue‏ القيم المختلفة المعرفة بواسطة کل عبارة حالة ‰6ع. جمیع الكود الذي يلي عبارة حالة ما )Case‏ حتی عبارة الحالة 

مء التالية ) هو التفرع الذي تتم معالجته عندما تتم عملية المقارنة. يمسك شرط اختياري ماع مءه٥(السطر‏ 16 ) أي شيء لا يمكن أن تتم مطابقته 
مع أي حالة موه أخرى . و عادة » عباراتهءه تجدول قيم وحيدة من أجل المقارنة . بإمكانها أيضا أن تتضمن قائمة ما من قيم مقارنة الفواصل 
المنفصلة ( السطر 12 ) » أو تعابير مقارنة مجال بسيط ( السطر 14 ) . 


تتضمن الفيجوال بيسك اختلافين لعبارات ۴| من أجل الاستخدام المتوازي . خذ العبارة التالية : 
If (gender = "F") Then fullGender = "Female" Else fullGender = "Male"‏ 
باستخدام الدالة ۴||» يتم ضغط هذه العبارة في عبارة إسناد وحيدة مع شرط مدمج : 
fullGender = IIf (gender = "F", "Female", "Male")‏ 
تملك الدالة |١۴‏ ثلاث معاملات نسبية محدودة بالفواصل لع†"|امل-ه ٠ء‏ . المعامل الأول هو الشرط » الذي عليه أن يظهر في قيم منطقية 
eanاB00إما‏ صح ه٣‏ أو خطأعواه۴ .المعامل الثاني يتم إعادته من قبل الدالة إذا كانت قيمة الشرط صح هں٣۲:‏ تعيد نتيجة الشرط الخاطئة العامل 

النسبي الثالث . من أجل الشروط البسيطة المخصصة لإعادة القيم إلى المتغيرات المشتركة »› إنه حقا دالة مفيد . ولكن مع أي شيء مفيد حقا » يوجد ثلاث 
تحذيرات . التحذير مع ۴|| هو أن أي شيء يظهر داخل العبارة ۴|| ستتم معالجته » حتى لو لم تتم إعادته كنتيجة . ولدينا هنا مثال خطير : 

purgeResult = IIIf (level = 1, PurgeSetl( ), PurgeSet2( ))‏ 
ستعيد العبارة بشكل صحيح النتيجة من كل من ( )51و۴ أو ( )2م5هوں۴ المبنية على قيمة المستوى . إن المشكلة » أو المشكلة المحتملة » هي أن 
کلا من الدوال ۰ ( )1٤٥مواں٥‏ ۰ ()5e2موPur‏ › سوف یتم استدعاءھا : إ ذا کان المستوی ھو 1 ۰ إن کل من ( )561٥واں۴‏ و ( )862مواں۴ سوف 
يتم استدعاءه » على الرغم من أن النتيجة من الدالة () 5611م و ںمفقط ستتم إعادتها . 
للمساعدة على تجنب مثل هذه التأثيرات الجانبية » أضافت الفيجوال بيسك 2008 معامل ۴| جديد . إنه يبدو تماما مثل الدالة ۴||» ما عدا من أجل الكلمة 
المحجوزة ۴| التي تحل محل الكلمة المحجوزة ۴||: 

ClasspurgeResult = If (level = 1, PurgeSetl( ), PurgeSet2( ))‏ 
سوف یتم الآن استدعاء ( )5611٥و‏ ں٣‏ أو ( )62و۴ فقط بناء على الشرط » و لكن ليس كلاهما . على الرغم من أن المعامل ۴| يبدو كدالة »وهو 
فعلاً معامل صحيح »> معروف بمعامل ثلاتي "A2‏ /16. في وقت الترجمة » تعالجه الفيجوال بيسك وتعالج معاملاته النسبية كمعاملات وعوامل وتولد 
المنطق المناسب . يأخذ تنوع للمعامل ۴| معاملين نسبيين فقط » باستثناء المعامل النسبي المنطقي ١هءاهه8‏ الأولي . 

realObject = If (objectl, object2) 

في هذا الإصدار للمعامل ۴|ء إذا أخذ المعامل النسبي الأول القيمة لا شيء وہ اماه » فإن المعامل سيعيد المعامل النسبي الثاني . إذا لم يكن المعامل 
النسبي الأول لا شيء واه - بمعنى أنه » إذا كان فعلاً شيء ما - فإن المعامل يعيد ذلك المعامل النسبي الأول عوضا . الهدف عدم إعادة لاشيء 
NON-Nothing‏ . 


تتضمن الفيجوال بيسك ثلاث أنواع رئيسية من الحلقات وهي : »...۴0۲ و For Each...Nex‏ و 00...L00p‏ . تسمح لك بتقسيم التكرار المتعاقب لكودك 
من خلال التفرعات » تضيف الحلقات الفائدة لكودك حيث أنها تتيح لك أن تكرر قطعة محددة من منطق مثبت أو متغير عدد من المرات . 
>lتlٽت For...Next‏ 
تستخدم الحلقة ×ه...۲٠۴‏ عداد عددي والذي يزداد من قيمة بدائية إلى قيمة نهائية » معالجا الكود ضمن الحلقة حالا من أجل كل قيمة متزايدة . 
Dim whichMonth As Integer‏ 
oO WALE NMOMEN = 1 TO 12‏ 
ProcessMonthlyData (whichMonth)‏ 
Next whichMonth‏ 
هذا نموذج يدور 12 مرة ( من 1 إلى 12 ) » مرة لكل شهر . يمكنك أن تحدد أي قيم للبداية والنهاية: يمكن أن يتم تحديد هذا المجال باستخدام متغيرات أو 
دوال تعيد قيم عددية . حالما يتم الحصول على قيم البداية والنهاية › لن يتم إعادة حسابها كل مرة خلال الحلقة » حتى لو تم استخدام استدعاء الدالة 
للحصول حد واحد أو كلا الحدين . 


Mone (Eda) SoS aman‏ > ل 
إن ال ااا ال ت 
HOE WMTORNMON EN lU UO MOREMN (ESSAY)‏ 
ProcessMonthlyData (whichMonth)‏ 
Next whichMonth‏ 
عادة » تزداد الحلقة بواسطة )1( خلال كل مرة . يمكنك أن تبدل هذه القيمة الابتدائية بضم عبارة Sp‏ إلى نهاية سطر العبارة ٥٣‏ ۴: 
EOE COUNEDOWN > 6O0 TO O SEE‏ 
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Next countDown 
يسمح لك تباين قاعدي إضافي أن تصرح عن متغير عداد الحلقة ضمن العبارة ذاتها . مثل هذه المتغيرات متاحة ضمن الحلقة فقط »ويتوقف وجودها عند‎ 
. خروجك من الحلقة‎ 
For whichMonth As Integer = 1 To 12 
ProcessMonthlyData (whichMonth) 
Next whichMonth 
For Each. . .Nex تاalح‎ 
. تطور عن الحلقة إم۴» وتعمل هذه الحلقة بحث خلال مجموعة من البنود المرتبة والمترابطة › من البند الأول حتى الأخير‎ ۴٥۲ ع2٥۸....ه× الحلقة‎ 
وتعمل أيضاً على كائنات المصفوفاتوءرهعA۲ و التجمعات٠ هاعم اامع. كما يعمل أي كائن يدعم الواجهة اطج۲مصںم ع۱ . إن التركيب مشابه تماما للعبارة‎ 
: ۴۲ لقیاسية‎ 
For Each oneRecord In setOfRecords 
ProcessRecord (oneRecord) 
Next oneRecord 


حلقات م00 . . .00 
تريد أحيانا أن تكرر قطعة من الكود طالما يكون الشرط المحدد صحيحا » أو فقط حتى يكون الشرط صحيحا . إن الترکیب و٥٥1...٥0‏ ينجز كلا من هذه 
المهام . تتضمن العبارة ممها...٥0‏ عبارة هام أو انهل التي تحدد الشروط من أجل المعالجة المستمرة للحلقة. على سبيل المثال » تعمل العبارة التالية 
معالجة ما لمجموعة ما من التواريخ» من بداية تاريخ ما إلى نهاية تاريخ : 
Dim processDate As Date = #1/1/2000¥#‏ 
Do While (processDate < #2/1/2000¥#)‏ 
عمال اة للبار ااا ت 
ProcessContent (processDate)‏ 
الهم اك الاتات الا ١‏ 
processDate = processDate.AddDays (1)‏ 
Loop‏ 
سوف تستمر معالجة البيانات في هذا النموذج حتى تلاقي المتغير ماة0ءءهء هم أو تجتاز التاريخ 2/1/2000ءالذي يشير إلى نهاية المعالجة . إن إصدار 
العبارة ااهل مشابه لما تقدم » ولكن نتيجة الشرط ستكون معكوسة : 
Do Until (processDate >= #2/1/2000¥#)‏ 


HOSP 
اجعل الشرط المضمن بسيطا أو معقداً كما تريد . واضعا العبارة انأل أو ءا عند أسفل الحلقة يكفل أن العبارات التي في داخل الحلقة سوف تتم‎ 
معالجتها دائما مرة على الأقل:‎ 
Do 


Loop Until (processDate >= #2/1/2000¥#)‏ 
إذا لم تتم مقابلة شرط الحلقة » سوف تتابع الحلقة التنفيذ ولم ينتهي تنفيذها . لذلك إذا أردت أن تخرج حلقتك عند نقطة ما ( و بالعادة أنت تفعل هذا ) » تأكد 
أن تتم مقابلة الشرط في النهاية . ويوجد حلقة أخرى مشابهة للحلقة ممه...00 » تدعى الحلقة اا۷ ١"...هاا.‏ وعلى أي حال »فإنها توجد من أجل 
توافق تراجعي فقط . استخدم بدلا منها العبارة ممها...00. 


عادة » عندما تدخل حلقة ما » فإنه لديك غرض من كل تكرار للعدد الكامل من المرات المحددة بالشروط الأولية للحلقة . من أجل حلقات ١۲٠۴ء‏ فتوقع أن 
تستمر من خلال المجال العددي المدخل أو مجموعة العناصر ,في حلقات م5 » فإنك تخظط لكي تحافظ على استمزار الحلقة طالما لم تقابل شرط الخروج 
حتى الآن . ولكن ربما هناك حلقات تريد أن تخرج منها باكرا . وتبلغ هذا باستخدام عبارة ×۴ 
ویوجد عبارتي × خاصتین بالحلقاتى|fا‌ممs-م |٥٥‏ : وهما : 
Exit For ¢‏ : 
تخر ج من الحلقة ا×م....إ۴0 أو الحلقة »...2۸ع ۴۵۲ بشكل مباشر. 


تخرج من عبارة ممه ]0...1 مباشرة. 
تخرج كل عبارة »ع من الحلقة التي تحوي العبارة : تستمر المعالجة مع السطر الذي يلي الحلقة مباشرة : 
olk ALEM oMEM — ll To 12‏ 
If (ProcessMonthlyData (whichMonth) = False) Then Exit For‏ 
Next whichMonth‏ 
N o ao CES CC OAD CE MLS CE A‏ 
يتم تصميم نموذج الكود للحلقة من خلال جميع ال 12 شهر . على أية حال فشل المعالجة من أجل أي شهر من ال12 شهر سوف يغادر الحلقة مباشرة »› 
تاركا جميع أعمال معالجة الشهر المتبقي . تخر ج العبارة 5٥‏ »ع بشكل مشابه من حلقات مه٠00...1‏ مباشرة. 
في عبارة حلقة الخروج ×۴ ضمن حلقات متداخلة oopsا (nested‏ حیٹ تد حلقة ما ضمن حلقة أخرى )» فإن الحلقة الموافقة فقط التي تحوي 
العبارة مباشرة يتم خروجها: 
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OE EMO = Û Mo 1Z 
For whichDay = 1 To DaysInMonth (whichMonth) 
If (ProcessDailyData (whichMonth, whichDay) = False) 
Then Exit For 
Next whichDay 
اك ااا اال ت‎ E E COE OO NE E EN EE 
ا اا م ال ال الا ت‎ 
Next whichMonth 


بما أن الخروج من حلقة ما يهجر جميع المسارات المتبقية خلال الحلقة » فمن المحتمل أنك تتغاضى عن عملية معالجة بيانات هامة والتي سوف تحدث 
بطرق متتالية » تتضمن الفيجوال بيسك عبارة هد نامه والتي تتيح لك أن تترك المسار الحالي فقط خلال الحلقة . يوجد تنوع لعبارات عu‏ ”٢ه‏ مختلفة 
من أجل كل نوع للحلقات : 
Continue For‏ : 
تقفز مباشرة إلى نهاية الحلقة »×ه....۴0 أو الحلقة ×ه۸...۸هع ۴٠۲‏ و تتجهز للمسار التالي . تتم زيادة متغير الحلقة ومقارنته مع المجال أو 
حدود التجمع. 
Continue Do °‏ : 
تقفز مباشرة إلى نهاية العبارة ممه]00...1 وتتجهز من أجل المسار التالي . تتم إعادة تقييم الشرط انال أو الشرط مااا۷. 
بما أنه تتم تقييم شروط الحلقة عند استخدام العبارات عنام ه» فإنه توجد مواعيد عندها يمكن أن تسبب مناه إغلاق الحلقة » كما عندما يتم إنهاء 
المسار خلال الحلقة مسبقا . في هذا المثال › تقفز العبارة ۴٥۲‏ مامه معالجة الشهور التي ليس لديها بيانات للمعالجة : 
Bo wien Mon EM — Û Mo O2 1 ٠‏ 
EF (MataAva1i lable (whICAMOSNER) — Halse) hen COMNEINUE EOL‏ 
RetrieveData (whichMonth)‏ 
ProcessData (whichMonth)‏ 
SaveData (whichMonth)‏ 
Next whichMonth‏ 


يجب أن تظهر جميع العبارات المنطقية في كودك ضمن إجراء ما » إما في إجراء فرعي » دالة ماء أو خاصية ما . على الرغم من أنه يوجد الآلاف من 
الإجراءات المسبقة الكتابة من أجلك كي تختار منها في مكتبات إطار عمل الدوت نت » فإنه بإمكانك أن تضيف إجراءك الخاص أيضاً. 


تبدأ الإجراءات الفرعية بعبارة تصريح ما و تنتهي بعبارة ااS "١‏ ۴. ويظهر جميع منطق إجراءاتك الفرعية بين هذين الفكين الرائعين . 
Sub ShowIngredients (ByVal gender As Char)‏ 01 


2 Dim theMessage As String = "Unknown." 

8 If (gender = "M"c) Then 

4: EheMessageê _ SNIDS Gand SNhailS ald PUPPY GOG LaillSs. 
5: Elself (gender = "F"c) Then 

6 theMessage = "Sugar and spice and everything nice." 
7 ACL 1E 

8ٍ MsgBox (theMessage) 

0S mE SUS 


يظهر السطر 1 سطر تصريح الإجراء الفرعي بأبسط نماذجه : على طوال الكتاب » سوف تجد أن هناك كلمات محجوزة إضافية والتي تجمل تصريحات 
الإجراء لتغير سلوكها . تبدأً العبارة مع الكلمة المحجرزة طu؟‏ (من أجل الإجراء الفرعي ( »متبو عا باسم الإجراء › nts‏ مdiمgrوShowln‏ . تحوي الأقواس 
التالية لهذا الاسم وسيطات ء١16٥‏ ”وم الإجراء الفرعي . تسمح الوسيطات لمقطع آخر من الكود الذي سيستخدم هذا الإجراء أن يمرر البيانات ضمن 
الإجراء» وأن يتلقى بشكل اختياري البيانات العائدة . يمكنك أن تدخل أي عدد من الوسيطات في تعريف الإجراء الفرعي : بشكل بسيط افصلها بفواصل . 
يعيّن كل وسيط الاسم بأن يتم استخدامه في الإجراء ( المتغير هلم هو في النموذج) و نوع البيانات ( محرفي هط٥)‏ . تتم معالجة المعاملات النسبية 
كمتغيرات مصرح عنها ضمن الإجراء > كما تم عمله مع المتغير ender‌gعلى‏ السطرین 3 و 5 . 

القيم المزودة بواسطة الكود المستدعي تعرف بالمعاملات النسبية 6ص u‏ وه . یتم تمریر جمیع المعاملات النسبية بالقيمة by value‏ أو بالمر جع 
٥ferencعr‏ رم . في نموذج الكود » سيتم تمرير المعامل النسبي الممرر إلى المتغير ملم هن بالقيمة › كما تم تعينها من خلال الكلمة المحجوزة اج۷ر8. 
تشير الكلمة المحجوزة المرتبطة ۴٥٩ر‏ إلى معامل نسبي ما سيتم تمريره بالمرجع . وإذا لم تدخل أي كلمة محجوزة › فإنه يتم فرض ۷1ر8 .تؤثر 
طريقة التمرير هذه فيما إذا حصلت تغييرات للمعامل النسبي ضمن الإجراء المحلي وتم إرسالها مرةٌ أخرى إلى كود الاستدعاء . على أية حال › تتأثر 
القدرة على تحديث البيانات الأصلية أيضا فيما إذا كانت البيانات من النوع ذو القيمةممرا مر/مر أو من النوع المرجعي مرا .٥/۵۲۵٣٤٤۲‏ و يشير 
الجدول التالي إلى السلوك المتبع عند دمج طريقة التمرير و نوع البيانات . 

طريقة التمرير -0-0- فوع البيانات السلوك 


التغيرات التي تحدث للإصدار المحلي من المعامل النسبي التي لا تملك التأثير على الإصدار 
الأصلي . 


Value type ByVal 
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التغيرات التي تحدث على الإصدار المحلي يتم إعادتها إلى الإجراء المستدعي › وتؤثر دائما على 
قيم البيانات الأصلية. 


Value type ByRef 


في معظم الحالات » إذا أردت أن تستمتع في تعديل القيمة لوسيط ما و امتلاك المتغيرات التي ترجع إلى المستدعي › استخدم 6۴ر8 وإلا » فاستخدم 
اة8. تشمل السطور من بداية 2 إلى 8 في نموذج الكود الجسم رلمط للإجراء »> حيث يظهر كل منطقك . سيتم استخدام أي متغيرات تم تعريفها 
لوحدها هنا في الإجراء أيضا » كما بالمتغير موهءءه ۷١ط‏ على السطر 2 » وينتهي الإجراء الفرعي دائما بعبارة bں؟ ٣۵‏ ۴. 


, يختلف تركيب الدالة نوعا ما عن الإجراءات الفرعية فى دعمها لقيمة عائدة فقط‎ 
O01 Function IsPrime (ByVal source As Long) As Boolean 
28 7 ى ا ل9 ار دد وه‎ 
3 Dim testValue As Long 
41 TF (Source < 2) Then 
9 Return False 
6 Elself (source > 2) Then 
7 For testValue = 2 To source \ 2& 
8: TE Source Mod eS EVaAlueE) > O) hen 
9 Return False 


102 EMO MÊ 

E Next testValue 
2 ERE EE 

E ReEUENn Irle 


IA ERS EUNEE TOM 

كما مع الإجراءات الفرعية » يظهر سطر التصريح للدالة أولا (سطر 1) » متبوعا بالجسم ( السطور من بداية 2 حتى 13 ) و بالاغلاق عبارة 0٣ع‏ 
nە۴uneti(السطر‏ 14) . يتضمن سطر التصريح تعريف نوع بيانات ما زائد بعد قائمة الوسيط . هذا هو نوع البيانات للقيمة النهائية كي تتم إعادتها إلى 
الكود المستدعي . استخدم قيمة العودة هذه في استدعاء الكود تماما مثل أي قيمة أو متغير آخر . وكمثال على ذلك » يستدعي السطر التالي الدالة مصا۴ء| 
و يخزن نتيجته المنطقية 2۸هامه8 في متغير ما : 

primeResult = IsPrime (23)‏ 
و لتدل على عودة القيمة › استخدم العبارة Return‏ „ يعمل نموذج الكود هذا على السطور 5و 9 و13 . ( قاعدة الفيجوال بيسك 6.0 ۷8 القديمة التي 
تتيح لك أن تسند القيمة العائدة لاسم الدالة لا تزال تعمل. ) 


لقد ذكرت الحقول منذ وقت مبكر قليلا » والتي هي متغيرات أو ثوابت تظهر ضمن فئة ما » ولكن خارج أي تعريف إجراء . 
O01 Class PercentRange‏ 
Public Percent As Integer‏ 28 
0Y HMol CIES‏ 
إن الخاصيات مشابهة للحقول :حيث يتم استخدامها مثل متغير أو ثابت على مستوى الفنة إام۷ه|-وءهاع. ولكن يتم برمجتها مثل الدوال > قابلة الوسيطات › 
و مالكة قيم عائدة » و متضمنة منطق كثير كما تطلب . و غالبا ما يتم استخدام الخاصيات لتحمي بيانات الفئة الخاصة مع المنطق الذي يتخلص من القيم 
الغير مناسبة . تعرف الفئة التالية خاصية وحيدة تدعم الوصل إلى الحقل المخفي(أو الخاص) ذو الصلة : 
Class PercentRange‏ 01 


2 ١ 8 100 انق د رة ن 0 ال‎ 
3 Private savedPercent As Integer 
04 Public Property Percent( ) As Integer 
05 ESE 

6 Return savedPercent 

07 End Get 

08 Set (ByVal value As Integer) 

9 If (value < 0) Then 

LOE savedPercent = 0 

I: Elself (value > 100) Then 

2 savedPercent = 100 

3s Else 

A savedPercent = value 

E EMA TE 

16 ENG Sel 


IY ERG EEOSeFE EV 
E ERG Cass 
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تحمي الخاصية "ه٠۲٠۴‏ ( السطور من 4 إلى 17 ) الوصول إلى الحقل اهءإ٠0۴ه»هء‏ ( السطر 3 )»> مصححة أي قيمة مزودة للمستدعي -٣ءااهء‏ 
لااممuءالتي‏ تجتاز المجال من 0 إلى 100 . تتضمن الخاصيات إسناد منفصل و استرداد المكونات » و تستدعي محددات الوصول أيضاً . تعيد ام6 
٣ccess0ه‏ (السطور من 5 إلى 7 ) قيمة مراقبة الخاصية إلى المستدعي . تدع 0۲ءوهءعه ه5( السطور من 8 إلى 16 ) المستدعي يعدل قيمة 
الخاصية . تتضمن عبارة تصريح الخاصية ( السطر 4 ) نوع بيانات والذي يلائم نوع البيانات المارة إلى داخل مومه ه5 ( السطر 8 ) . هذا هو 
نوع البيانات لمجموعة القيم أو المستعادة من قبل المستدعي . لكي يستخدم هذا النموذج خاصية امهم » أنشئ حالة ما من الفنةَ مو2 rcer†Rم۴»‏ و 
بعدئذ استخدم الخاصية : 
Dim activePercent As New PercentRange‏ 
activePercent. Percent = 107 ' An out-of-range Integer‏ 
E I Die ole S LOO, DoE IONE‏ 
يمكنك أن تنشئ خاصيات للقراءة فقط read-only‏ أو للكتابة فقط -only‏ -هاامس تتضمن الكلمة المحجوزة القراءة فقط ق¡ذ ReadOnly‏ أو الكتابة فقط 
Write ny‏ تماما قبل الكلمة المحجوزة Property‏ في عبارة التصريح (السطر 4( > و ترك محددات الوصول 0۲ءءهعء مه الغير محتاج إليها > لا تحتاج 
الخاصيات لأن تربط بالحقول. يمكنك أن تستخدم الخاصيات لتجمع و ترتب أي نوع قيمة » و تخزنه و تمثل عليه بأي طريقة تشاء 


بالعودة إلى الأيام القديمة الجيدة للفيجوال بيسك 6.0 » فإنه بإمكان الإجراءات أن تظهر تماما في أي مكان في ملفات كودك المصدري . عليك أن تفتح 
ملف مصدري ما › اكتب دالي ما »› و اذهب : لقد كان ذلك سهلاً . مع الانتقال إلى الدوت نت » فإنه جميع إجراءات الفيجوال بيسك يجب أن تظهر الآن 
ضمن فئة معرفة ( أو تركيب أو وحدة برمجية ). 
Class Employee‏ 
SUS SEAFEMaCaAETOR‏ 


ا0 ا 
Function TotalVacationTaken () As Double‏ 


BDO HURME EON 
HRS CLASS 
. عندما تنشئ حالات لفئتك فيما بعد في الكود › يتم استدعاء الطرق مباشرة من خلال حالة الكائن‎ 


Dim executive As New Employee 


E CUE A VE - SEE E MEE EE 1 o ( 


تتيح لك الحلقات و العبارات الإضافية المتوفرة في الفيجوال بيسك إعادة توجيه كودك المبني على البيانات » تتضمن اللغات عبارات أخرى قليلة والتي 
تدعك تضبط العمل في أكثر من طريقة مباشرة. 


تتيح لك العبارة 60٠٠٠١‏ القفز مباشرة إلى موقع آخر ما ضمن الإجراء الحالي . والغرض من القفز دائما هو عنوان السطر اعطها ها »وهو موقع سطر 
مسمى في الإجراء الحالي . تظهر جميع عناوين السطور عند بداية السطر المنطقي › و تنتهي بنقطتين . 
EOP USE E‏ 
GetValuesFromUser (numerator, denominator)‏ 
If (denominator = 0) Then GoTo PromptUser‏ 
quotient = numerator / denominator‏ 
في هذا النموذج ¢ تقفز العبارة G00‏ عائدەة إل العنوان ser‏ ل Prompt‏ عندما یکتشف الکود قیمة بیانات غیر مسموح بھا . وتستمر معالجة البيانات مع 
السطر التالي مباشرة للعنوان مولاامصه۲٥.‏ لا يمكنك أن تستخدم نفس اسم العنوان مرتين في نفس الإجراء» على الرغم من أنك تستطيع أن تعيد استخدام 
أسماء العنوان في إجراءات مختلفة. إذا أردت » ادخل عبارة منطقية أخرى على نفس السطر بوصفها عنوانك ءتماما بعد النقطتين » رغما من أن كودك 
سيكون أسهل نوعا ما حتى تقرأه إذا أبقيت العناوين على سطورها الخاصة . 
LabelAlone:‏ 
MSGEBOX (EES al alone)‏ 
LabelAndCode: MsgBox ("Together again.")‏ 
ق کد اين ملعد في كر كا قري كن لار ةو وه هي ر اة من اواك الاصر من الفيجوال بيسك التي ت تتم مراقبتها بشكل أقرب 
بواسطة وكالات البرمجة العالمية المزعجة » متل اللجنة العالمية للمحافظة على ٠آ60.تدقق‏ ق لك المجموعة أبضا كتب الكرمبير ترات باحثة عن مراجم 
ازدراء ليس لاسم تنظيماتها أن تجد أي شيء متل ذلك في هذا الكتاب » و لكن قضيته الجوهرية مفرطة في الاستخدام للعبارات التي يمكنها أن تقود إلى 
تغيير مسار الكود » كالتالي : 


Dim importantMessage As String = "Do" 
GoTo StepZ2 

Step6: importantMessage &= "AG!" 
COS SES 

Step3: importantMessage &= "wit" 
GoTo Step4 

Step2: importantMessage &= "wn " 
GoTo Step3 
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Step5: importantMessage &= "CK-G" 
GoTo Step6 

Step4: importantMessage &= "h I" 
GORG SEEPS 

Step7: MsgBox (importantMessage) 


يقول بعض الناس أن مثل هذا الكود صعب للقراءة . ويستدعيه آخرون لمهمة سرية . مهما تدعوه › فإنه يصنع كود صعب جدا للمراجعة و للحفاظ عليه. 
من المحتمل أنه يجب عليك أن تحافظ على عين واحدة عند استخدامك لعبارات :60٥٠١‏ وإذا لم تفعل » فربما سيفعل ذلك شخص آخر . 
تضع الفيجوال بيسك بحد ذاتها قيود على الاستخدام .60٥١‏ ليس بإمكانك أن تقفز إلى أو من العبارات المتشابكة المحددة التي سوف تنتج في كود ابتدائي 
أو قيم بيانات بشكل غير مناسب. وعلى سبيل المتال » لا يمكنك أن تقفز إلى المنتصف من العبارة ۴٠۲...»‏ من خارج العبارة » بما أن متغير عداد 
الحلقة و مجالات البداية و النهاية لن تكون مبدئية كما ينبغي. 
I MN CCD SSN‏ 
GoTo InsideTheLoop‏ 
ROE COUIEOE = JM Wo 1O‏ 
InsideTheLoop:‏ 
MsgBox ("Loop number: " & counter)‏ 
Next counter‏ 
على أية حال » حالما تكون في داخل الحلقة » فإنه بإمكانك القفز إلى عناوين السطر الذي يظهر أيضا في الحلقة » وهو مقبول أن تقفز خارج الحلقة 
مستخدما .60۲٠‏ تفرض بعض التراكيب المتعددة السطور الأخرى قيود مشابهة . 


ليس بإمكانك فقط أن تقفز في مكان قريب ضمن إجراء ما مستخدما 607٠‏ » ولكن تستطيع أيضا أن تقفز تماما خارج الإجراء في أي وقت تريد مستخدما 
العبارة ›Return‏ وعادة › يغلق إجراء ما عندما تصل معالجة بيانات السطر الأخير للكود في الإجراء : تستمر بعدئذ معالجة البيانات مع الكود الذي 
استدعى الإجراء . تزود العبارة ١إ‏ ںهR‏ طريقة ما لتغلق الإجراء قبل الوصول إلى النهاية . في إجراء فرعي » تظهر عبارة ٢إ‏ ںام8 بحد ذاتها كعبارة ما 


REE UE 
في الدوال » يجب أن تتضمن العبارة القيمة لتعاد استجابة لاستدعاء الكود : متغير ما» محرف ما٠ أو تعبير ما والذي يجب أن يصل نوع البيانات ذات‎ 
. القيمة العائدة المحددة للدالة‎ 
Return 25 


تحررت الدوت نت السابقة ۲ ۴٣٥-..E‏ من الفيجوال بيسك المستخدمة عبارة »ع لتترك بشكل مباشر إجراء ما . و لا تزال هذه مدعومة في الدوت نت. 


:Exit Sub 
و هي تغلق إجراء جزئي ما.‎ 
:Exit Function 
. وهي تغلق دالة ما‎ 
:Exit Property 
وهي تغلق خاصية ما.‎ 
عند الخروج من دالة ما » فإن العبارة نام۴ »ع لا تتضمن طريقة ما اتخصص قيمة عودة . عليك أن ترتب قيمة العودة بشكل منفصل باسناد قيمة‎ 
. العودة للاسم من الدالة‎ 
Function SafeDivide (ByVal numerator As Double, 
ByVal denominator As Double) As Double 
ا ا من الع لاناك ادا ت‎ 0 
uF (Gen omina Eo > O O) men 
د د ان فش اا ر‎ 0 
SafeDivide = 0.0F# 
MSE EUDEE LON 
EN 
Return numerator / denominator 
EMA EUNEEI OR 


تقدم عبارات مه8 و ١ع‏ توقف مباشر لتطبيق الفيجوال بيسك. تغلق العبارة هع برنامجك مباشرة » ملغية جميع الكود الإضافي و معالجة البيانات 

( على الرغم أنه تم توضيح مصادر مكتسبة محددة ). 

توقف العبارة مه5 المعالجة فقط عندما تنفذ تطبيقك ضمن المصحح ۲ع ووںطهل »› كما في بيئة تطوير الفيجوال استديو . تحول مه6 التحكم إلى البيئة › 
متيحة للمطور أن يفحص ويغير البيانات والكود كل ما في الإمكان قبل الاستمرار مع البرنامج. إذا لم تتم مناقشة مه5 في تطبيق مستقل منقذا خارج 
المصحح »إنه يحث المستخدم كي يصحح التطبيق مستخدما أي مصحح منصب على شبكة الحاسوب . ليس من الضروري أن تقول »› إن المستخدم لن 


يتسلى . 
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إن الفيجوال بيسك هي لغة قيادة الحدث ١۷6أ۸۲-0۲٥۷ع.‏ وهذا صحيح بصورة خاصة لبرامج مكتوبة كي تنفذ على سطح مكتب ويندوز . بعد بعض 
الأوليات الهامة » يتحكم المستخدم على العموم بجميع الأحداث في البرنامج . من يعرف ما سوف يعمله المستخدم المولع . ربما ينقر هنا . ربما تكتب 
هناك. من الممكن أن يكون فوضى وهر ج . ولكن كل ما يفعله المستخدم » سيعلمك برنامجك حوله من خلال الأحداث كأ" ۷6م. 
منذ الأيام الأولى للويندوز » استخدمت برامج سطح المكتب مضخة رسالةم ام ٥29ءءه"‏ لكي تتصل بالمستخدم و أحداث النظام لكودك . مدخلات 
الفأرة و لوحة المفاتيح » و أحداث مولدة للنظام Qعأه6۲٠٠و-"6اءرءء‏ و إشعارات أخرى من تدفق المصادر الخارجية إلى طوابير الرسالة 
gueue‏ essageم‏ المشترکة للبرنامج . تطيل مضخة الرسالة هذه الرسائل واحدة تلو الأخرى › وتفحصها » تمدها بمساحات مناسبة من كودك. 
في برمجة الويندوز التقليدية › إنك تقوم بإظهار مضخة الرسالة بمهارة بنفسك › مدخلا الكود الذي يصنع استدعاءات مباشرة لإجرائية معالجة الحدث 
event-handling‏ المبنية على نوع الرسالة . في برنامج الفيجوال بيسك ( كل من الدوت نت و فيما مضى ) » تدعم اللغة مضخة الرسالة من أجلك . 
و تحلل الرسائل وكأنها مفرغة بواسطة المضخة خارج طابور الرسالةء و تقودها إلى الكود المناسب . ويظهر في الدوت نت الكود ضمن فئات . و حالما 
تملك فئة ما فرصة ما لتحلل الرسالة » فإنه يمكنها أن تولد حدث ما٠‏ والذي تتم معالجته أخيراً من قبل معالج الأحداث۲ءال١٣ة"‏ ممه ٠‏ إن الإجراء 
الفرعي الذي كتبته كي يستجيب للفعل. وهذا الاستدعاء لمعالج يعرف بإطلاقوہ ۶ حدث ما . 
لذلك يوجد جزآن للحدث : )1( بعض الكود الذي يقرر إطلاق الحدث . (2) معالج الحدث الذي سوف يستجيب للحدت الذي تم إطلاقه. 
إن الأحداث بالفعل هي استدعاءات غير مباشرة تماما للإجراء . بدلا من امتلاك الكود الرئيسي استدعاء إجراء فرعي آخر بشكل مباشر» فإنه يطلب من 
الدوت نت أن تستدعي الإجراء الفرعي الآخر من أجله » ممررةٌ معاملات نسبية خاصة ربما يرغب الكود المستدعي تضمينها . لذلك › لماذا تريد أن 
تعمل هذا بدلا من صنع استدعاء مباشر لإجراء فرعي ؟ من أجل شيء ما » تتيح لك هذه طريقة الغير مباشرة أن تضيف معالجات حدث لمدة طويلة بعد 
أن تتم كتابة كود إطلاق الحدث و |ا؟-٤"‏ ه۷ الابتدائي. هذا جيد » بما أن كود إطلاق الحدث ممكن أن يكون في مجمع ثانوي تمت كتابته منذ سنين . 
المنفعة الثانية هي أن حدث واحد يمكنه أن يطلق معالجات حدث متعددة. عندما يتم إطلاق الحدث » سيتم استدعاء كل معالج حدث » وكل واحد يستطيع أن 
ينجز أي منطق خاص موجود في معالج الإجراء الفرعي. 
يمرر الكود الذي يطلق الحدث بيانات خاصة ٥أ‏ 6م5-ا ۷٠"‏ بالحدث إلى معالج أو معالجات الحدث الهدف من خلال قائمة وسيطات الحدث . من أجل 
أن يعمل استدعاء الإجراء الفرعي الغير مباشر > يحتاج معالج الحدث لأن يحوي العدد الصحيح من المعاملات النسبيةء في الترتيب الصحيح > کل نوع من 
البيانات المحددة و المتوقعة . تعرف عبارة الحدث ۸٣٥۷ع‏ هذا العقد (الاتفاق) بين الحدث و المعالج . 
Public Event SalaryChanged (ByVal NewSalary As Decimal)‏ 
تعرف عبارة الحدث ٤٣۷6ع‏ حدث ما مسمى ب لع9١۸2٣۷اهاجS‏ مع معامل نسبي وحيد » ذو قيمة عشرية اج"أءه0.إن رغبة أي معالج حدث 
في أن يراقب الحدث يجب أن يلائم توقيع المعامل النسبي . 
Sub EmployeePayChanged (ByVal updatedSalary As Decimal)...‏ 
يمكن أن تحدث الأحداث ءأ" ۷6ع من أجل أي سبب تعتبره ضروريا :حيث لا تحتاج الأحداث أن تقييد إلى مستخدم أو أعمال نظام . في نموذج هذه 
الفئةء يتم إطلاق حدث ما كل مرة يتم عمل تغيير لراتب الموظف . تنجز العبارة E۷6١٤‏ عءأجR‏ الإطلاق الفعلي للحدث » مخصصة الاسم للحدث ليتم 
إطلاقه » و مجموعة من المعاملات النسبية في الأقواس . 
Public Class Employee‏ 
BUBE Name AS SEEIMG)‏ 
Private currentSalary As Decimal‏ 
Public Property Salary() As Decimal‏ 
SE‏ 6 
Return currentSalary‏ 
End Get‏ 
Set (ByVal value As Decimal)‏ 
currentSalary = value‏ 
RaiseEvent SalaryChanged (currentSalary)‏ 
End Set‏ 
ERA EEFOBpeFEFLY‏ 
Public Event SalaryChanged (ByVal NewSalary As Decimal)‏ 
HME CESS‏ 
لا تتم إضافة معالجات الحدث بشكل مباشر إلى الفئة . عوضا عن ذلك » تتم إضافتها إلى حالة ما للفئة . الحالة »> مصرح عنها كحقل فئة ما » يجب أن يتم 
تعريفها استخدام الكلمة المحجوزة كأ" ۷۸٤۷6‏ الخاصة › التي تخبر الفيجوال بيسك أن هذه حالة سوف تعالج الأحداث . 
Public WithEvents MonitoredEmployee As Employee‏ 
معالجات الحدث هي إجراءات فرعية مألوفة » ولكنها تتضمن الكلمة المحجوزة كءال" ه1 لتشير أي حدث تتم معالجته . 
Private Sub EmployeePayChanged (ByVal updatedSalary As Decimal) Handles‏ 
MonitoredEmployee.SalaryChanged‏ 
MsgBox ("The new salary for " & MonitoredEmployee.Name & " is " & updatedSalary)‏ 
Ol SUIS‏ 


PUNE SUS Hi HeET eK) 


MonitoredEmployee = New Employee 

MonitoredEmployee.Name = "Fred" 

MonitoredEmployee.Salary = 50000 ' Triggers event 
El SEO 


17 


الفصل الثاني:تقديم الفيجوال بيسك. Mhm76‏ 


عندما يكون الراتب مجموعة » تطلق خاصية اهاه للفئة معرهام "ع الحدث ٥129٥١‏ ۷إaاجS‏ مستخدمة أمر الفيجوال بيسك 
.NRaiseEvent‏ و هذا يولد استدعاء ما لمعالج الحدث ٣129٥4‏ ۴ayءعرoامصع»‏ الذي يعرض بالنهاية الرسالة . الأحداث المبنية داخل الفئات 
Windows For‏ في الدوت نت N٤۲‏ .تعمل تماما مثل هذا ء› ولكن د من آن تراب مسي ر يادة الراب . فإنها تترقب نقرات الفأرة و ضربات 
لوحة المفاتيح . تستخدم جميع أحداث النظام هذه توقيع معاملات نسبية ما مشترك. 

Event EventName (ByVal sender As System.Object, ByVal e As System.EventArgs) 
يطابق المعامل النسبي المرسل ٠هل دهءالحالة للكائن الذي يطلق الحدث » في حال احتاج المستدعي اختبار أعضاءه .إن المعامل النسبيم هو كائن ما‎ 
System.EventArgs ةiفll إلى المعالج من خلال حالة فئة وحيدة . ا تملك‎ event- -specific يتيح للمستدعي أن يرسل بيانات خاصة بالحدث‎ 
.Sرك#‎ ٠.٤۷٥۸۲۸ ۲وئs الكثير على طول مع الأعضاء » و لكن العديد من الأحداث تستخدم فئة بديلة و التي تشتق من‎ 


الفئات و التراكيب و الوحدات البرمجية و العدادات و الواجهات و التفويضات - أنواع الدوت نت الرئيسية ‏ لا تعوم تماما فقط في كود تطبيقك .و عليها 
جمیعا أن تصنف و تدار في فضاءات أسماء ›»namespaces‏ یزود فضاء الأسماء هرم ما لأنواعك »> جزء من شفة مملوكة في بناية شجرية الشكل 
-shaped‏ -۵عع) حيث يملك کل نوع بیت » بعض هذه البيوت ( أو العقد ) > مثل النظام اكل ٠‏ تحصل على مجموعة كبيرة مناسبة مع ج جميع أنواع 
هذه العائلات الساكنة هناك . الآخرون ؛ مثل كاه" ٠".‏ 8اءلS‏ »› ربما تملك بضعة أنواع تسكن في مساكنها الكافية . ولكن كل نوع يجب أن يعيش في 
الهرم. 
في > الهرم ذاته يوجد اهطهاB‏ » و ليس عقدة بذاته » و لكن كلمة فيجوال بيسك محجوزة والتي تشير إلى جذر كل الجذور . بإمكانك أن تدخل 
اطهاB‏ عند إرجاع فضاءات الأسماء الخاصة بك » ولكن استعمالها مطلوب فقط ومتى تتركها فسوف تسبب فوضى بين فرعي فضاء أسماء. 
بشكل مباشر تحت اهطها6يوجد فضاءات أسماء عالية المستوى |ع۷ه|ا-مه) قليلة > متضمنة "ءاءل؟ر اموه ءi.‏ يحوي كل فضاء أسماء عالي 
المستوى |ع۷ها-مه] فضاء أسماء ثانوي » و كل من تلك تحوي فضاءات أسماء مستوى ثالث اع۷٠|-ل۸۲]‏ إضافية » و هكذا . يتم إرجاع عقد فضاء 
الأسماء بنسبة أحدها إلى الآخر مستخدما ترميز النقطة”اهل“ . 
System.Windows.Forms‏ 
هذا يحدد فضاء أسماء ۶ ۴٥۲۳"‏ على المستوى الثالث . بإمكانك أيضا أن تكتب 
Global.System.Windows. Forms‏ 
الذي يعني نفس الشيء . أيضاً يتم دعم فضاء أسماء نسبي: 
E SEINS‏ 
على أية حال لاستخدام فضاءات أسماء نسبي » عليك أن تخبر كود الفيجوال بيسك لكي يتوقعها . يوجد فضاءات أسماء عديدة هناك » و ربما يوجد أماكن 
فضاءات أسماء ۴0۲۳۶5 عديدة في الهرم. 


قبل أن يتم استخدام فضاءات الأسماء في كودك » كان من الواجب إسناد دليل لها أو مرجع ل٥٥١‏ 6١8؟هم‏ وجلبها ١مم"‏ بشكل اختياري . يعين 
إسناد دليل أو مرجع إلى فضاء الأسماء ملف المجمع اا0 الذي يحوي أنواع فضاءات الأسماء تلك. اعمل كل من هذين الفعلين من خلال 
التبويب"مراجع وع" ع۲ه؟ ه8" من نافذة خاصيات المشرو عءها هم۴۲0 ءءهزممم. ( انظر الشكل التالي) 


Application 
1 Unused Reterencez... 1 Reterence Paths... اه‎ 
Feferences: 
Compile 
Reference Hame Type| Yer Copy Local Path 
Debug System NET 2000 False CIN DOS Microsoft. HE T Framework 2. 0.572 7S 
System. Core NET 3500 False C:*Praogram FilestR eferernce A4ssermblieshMicrosoftFrarner 
Bet System.Data NET #2A000 False CI HDOS Microsoft. HE T Framework w2. 0.BOFA7™S 
ISTE System.Data. DataSelEmtensio... NET 35.00 False C:Pragram FileshR eference A4ssernbliesh Microsoft Frames! 
System. Deployment .HET 2ZUDDO False CIH ODOS Microsoft. HET Framework 2.0.5DF ATS 
Resources System. Drawing .HET 2A0UDO False CIN OOS Microsoft. MET Framewarktyw2.0.5DF ATS 
System Windows. Forrns .HET ZDUDDO False CINDO WS Microsoft. HET Framework w 2.0. 5OF ATS 
Services System. îêrnl .HET ZAUDDO False CINDO WS Microsoft. MET Framewarktyw2.0.5DF ATS 
System. #êrml. Lina .HET 3500 False C:*Pragram FileshR eference A4zsermbliesh Microsoft Frames 
Settings 
Signing 3 
My Estensions 3 17 [ 3 
Security ...ل‎ r 
Publish Imported namespaces: 
Microsoft. WisualB asic 
#] Microsoft.YWisualB asic e 
ww] System E 
w#] System.Collections 
4#] Systerm.Collections.G eneric 
w#] System.Data 3 
|] System.Drawing 
4#] Systerm.Diagnastics 2 


في الحقيقة » إنك لم تشير إلى فضاءات الأسماء في اا0 » ولكن بالأحرى الأنواع » و جميعها يحدث لأن تقطن في فضاء أسماء خاص . على أية حال » 
للنوع اا0 الرئيسي المزود بإطار عمل الدوت نت › إنه ضمنيا نفس الشيء . في الحقيقة » حتى الميكروسوفت سمت العديد من ال ]ا لمجارات 
فضاءات الأسماء التي تتضمنها. يتضمن |ال."6اءر5 أنواع ضمن فضاء الأسماء "ءy؟.‏ تتضمن System.Windows.F0r™s.d||‏ أنواع 
معينة لتطبیقات ١ ۷1۸۵0۷8 ۴٥۲۳٣5‏ و تظهر كل هذه الأنواع في فضاء الأسماء 0۲۳"8 ۴. System .Wi "0W‏ أو أحد فروعها . 

إذا لم ترجع اا0 في مشروعك » فإنه ولا شيء من أنواعها سيكون متوفراً لديك في كودك . تحمّل الفيجوال استديو مراجع عديدة داخل مشروعك بشكل 
آلي مبنية على نوع المشروع الذي تنشئه أنت . و يظهر الشكل السابق المراجع الافتراضية التسعة المحتواة ضمن تطبيق ۴0۲"5 sSس0ل"‏ |۷ وهي : 
System.Deployment« System.Data.DataSetExtensions. System.Data« System.Core«‘ System‏ « 

. System.Xml.Linqy« System.Xml« System.Windows.Forms<System.Drawin 
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حالما تعمل على إرجاع مكتبة فئات ما ( أو أنواع أخرى ) في كودك » فإنك تتمكن من الوصول لأي من فئاتها بكتابة الاسم الكامل لفضاء أسماء تلك الفئة 
. على سبيل المتال » الفئة للفورمالتي تکون على الشاشة 6۸ ٥۸-٥۲٥‏ یتم إرجاعھا بو اسطة .System.Windows. ۴0۲" S.۴0۲۳‏ وتلك ثلاث 
مستويات إلى أسفل الهرم » وبعض الفئات هي أعمق حتى . 
لتتجنب كتابة جميع فضاءات الأسماء الطويلة هذه عدة مرات متكررة ءفإنه تتضمن الفيجوال بيسك ميزة 5٣م"‏ |. حالما يتم جلب فضاء الأسماء › 
فبإمكانك أن تصل لأي من الأنواع في فضاء الأسماء بدون تحديد اسم فضاء الاسم . إذا جلبت فضاء الأسماء System.Windows.۴0۲"s‏ › عليك 
فقط أن تكتب ٥۲”‏ ۴“لتدخل الفئة .۴٠۲۳"‏ يظهر النصف السفلي من الشكل السابق كيفية ترتيب هذه الواردات من خلال خصائص المشروع .إن القائمة 
namespaces”‏ ortedمص|ا“‏ تظهر جميع فضاءات الأسماء المرجعية المتوفرة . ببساطة ضع علامة صح على الفضاءات التي ترغب أن تجلبها لقد 
تم وضع علامة صح على ۴0۲"8 .sسWindow. System‏ مسبقا وبشکل افتراضي في تطبیقات "۴0۲ .Wi۸d0 WS‏ 
بإمكانك أيضا أن تجلب فضاء أسماء مباشرة في كودك المصدري . استخدم العبارة كااهم "| من بداية ملف الكود المصدري : 
Imports System.Windows.Forms‏ 
تدعم العبارة كأامم "| اختصارات فضاء أسماء » أسماء قصيرة و التي تمثل فضاء الاسم الكامل في كودك . باستخدام العبارة : 
Imports Fred = System.Windows.Forms‏ 
تتيح لك إرجاع الفئة ۴٥۲۳‏ مثل “۴۲٠۵.۴٥۲۳.”‏ و ليس مثل قائمة الإيرادات في خصائص المشروع » التي تؤثر على كامل المشروع › تؤثر العبارة 
|٤6‏ في ملف کود مصدري وحید والمكتوبة فيه فقط . 


بشكل افتراضي ٠‏ تظهر جميع الأنواع و الفئات في مشروعك في مستوى فضاء أسماء أعلى |ام۷٠ا-مه†‏ والذي يواجه اسم مشروعك . من أجل تطبيقات 
Windows Forms‏ » و يدعی فضاء الأسماء الافتراضي هذا ب ica10۸1اpمwsA٥doہNİ.‏ ولتحدد مستوی فضاء أسماء أعلی مختلف -م٥)‏ 
ام۷ه| » غيّره من خلال المؤشر ۸٠هام‏ م۸ لخصائص المشروع › في الحقل ”2ceمsم “R00 "a‏ . و تظھر جميع الأنواع في مشروعك في 
فضاء الأسماء هذا : إذا حددت فضاء أسماء مزود من قبل ميكروسوفت ههام مدك-ا؟موم۲ ءا موجود كفضاء أسماء جذري لمشروعك › سوف تظهر 
جميع فضاءات الأسماء في مزيج فضاء أسماء مخصص في الأنواع الموجودة مسبةا . من أجل التطبيقات المستقلة » هذا المزيج سوف يكون واضحا فقط 
من كودك . 
من فضاء الأسماء الجذر » يمكنك أن تضع أنواع ضمن فضاءات أسماء ثانوية باستخدام العبارة #مع2ةمsئه"هلNN.و Namespace‏ هي عبارة مقطع ما 
ي بالعبارة c8‏ 2ےمNames‏ ndع.‏ سوف یتم احتواء آي أنواع أنشأتها بين العبارات End Namespace Namespace‏ في فضاءات 
الأسماء الثانوية تلك. و مثالا على ذلك » إذا كان فضاءك الأسماء الجذر هو 20۸1ء أامم ۸س0 ١۷1"0‏ فإن العبارات التالية تنشئ فة ما و التي اسمها 
JaJ‏ ھر WindowsApplication1.WorkArea.BasicStuff.BusyData‏ : 

Namespace WorkArea.BasicStuff 

Class BusyData 


NEL CLASS 
End Namespace 
: بإمكانك أن تدخل كعبارات فضاء أسماء متعددة في كودك كما تدعي الحاجة . ويتم تزويد ذلك بإدخال فضاءات أسماء أيضاً‎ 
Namespace WorkArea 
Namespace BasicStuff 
Class BusyData 


MAG CEES 
End Namespace 
End Namespace 


قدمت الفيجوال بيسك 2005 فضاء أسماء جديد”ل1“ في مستوى أعلى |ع۷٠ا-مه)‏ » مصمما لتبسيط مهام برمجية مشتركة . وأضافته الميكروسوفت إلى 
اللغة جزئيا لترسم بسالة عرض فيجوال بيسك الإصدار 6.0 داخل ملف الدوت نت . و لكن معظمه ليس حقيقيا حيث أنه تمثيلي . يجمع ¥ عموما 
ميزات مستخدمة والتي تنشر حاليا حول مكتبة فئة إطار العمل )۴CL( Framework Class Libary‏ › و تضعھا في ھرم صغیر -أہiہ٣‏ 
hierarchy‏ للدخول المناسب . إنها بالفعل ليست أكثر تعقيداً من ذلك . و يتم تنظيم الهرم بإحكام » مع أقسام المستخدم › التطبيق » و معلومات الكمبيوتر 
الخاصة . يتم استخدامه تماما كأي جزء آخر من إطار العمل » رغما من أنك لا تستخدم الكلمة المحجوزة كأاهم "| لتدخل عناصرها بطريق نسبية . 
على أية حال » إن ل سهلة جد للاستخدام > لتظهر عدد الإصدار لتطبيقك » على سبيل المثال » استخدم العبارة التالية : 

MsgBox (My.Application.Info.Version.ToString) 
يتضمن‎ ۰ | 465 Forms تكون بعض مناطق فضاء الأسماءر“ ديناميكية : و تضاف فئات أو تنقل عندما تعدل كودك المصدري . في تطبيقات‎ 
مداخل لكل صيغة من صيغ المشروع . عندما تضيف صيغا جديدة » عندها تتم إضافة مدخلات جديدة بشكل أوتوماتيكي . ثم يصنع‎ ۸۷.۴0۲۳١5١ الفرع‎ 
. عنوان المرجع لكل صيغة متاحة للاستخدام في كودك‎ 1۷.۴٥۲۳" المشروع‎ 

My.Forms.Forml.Text = "Welcome" 
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مشرgع‏ nllكتڊ:Project The Library‏ 
يعمل هذا المشروع على إدارة قاعدة بيانات كتب وبنود وسائط أخرىءويتحكم بكيفية نقل هذه البنود بين رفوف الكتب والزبائن.يحتاج البرنامج أن يمتلك 
ميزات خاصة بالزبائن والإدارة.وسيتضمن تقارير متنوعة ءبما فيها طباعة فاتورة بنود المخرجات للزبون.وأهم من هذا كلهءيحتاج أكواد الطباعة وقراءة 
تعريف الأدوات(الوسائط المركبة على الكمبيوتر)ءإنه يبدو كثير على أن يقوم بعمله شخص واحد فقطوإنه مشروع قابل للزيادة في الحجم.ولكن لن أقوم 
بعمله بنفسي»سوف تساعدني.فمع بعضنا البعض»ومن خلال صفحات هذا الكتاب»سوف نصمم کلانا هذا البرنامج»ونطور کوده»وسنجلب المتعة 
للمستخدمين. ما تبقى من مستندات هذا الفصل هي الميزات الرئيسية لتطبيق إدارة المكتبة. 


نظام المكتبة سيعمل على إدارة بيانات مفصلة بالكتب وبنود الوسائط الأخرى»إيجاد هذه البيانات»وإدارة وترتيب التفاصيل والحالات بالنسبة لكل نسخة من 

أي بند.ولجعل هذا حقيقةءفإن برنامج المكتبة سيعمل التالي: 
> يسمح للمدراء أو الزبائن من البحث عن بنود حالية في البيانات المفصلة.سيسمح البرنامج بالبحث بالاعتماد على العديد من الخاصيات المختلفة 

لكل بند. 

> دعم طرق البحث المتنوعة »من ضمنها بواسطة العنوان»بواسطة اسم المؤلف»بواسطة الموضوع أو تصنيف العنوان(مثل كتب علوم 

الإسان: ..)ءأو بواسطة كلمات مفتاحية متنوعةءأو بواسطة اسم دور النشر التي لها علاقةءأو بواسطة اسم الرقم المسلسل أو المجموعة التي 
تحتوي ذلك البندءأو بواسطة رقم كود التعريف المرتبط بالبند الحقيقي. 

تحدید نتائج البحث بواسطة موقع البندءأو بوساطة نوع الوسائط(کتاب»سيدي»ءديفيدي»إلخ) . 

دعم التعريف واستخدام المواقع المادية المميزة.فالزبون لديه كتب ووسائط تخزين في ثلاث مواقع مختلفة ضمن البناء»ومن ضمنها خزانة 

تخزين صغيرة للبنود النادرة الاستخدام. 

> عرض تفاصيل البند المستخرج ضمن واجهة نمطية استعراضية معروفة(شائعة). على سبيل المثال»عند البحث عن كتاب بواسطة العنوانءينقر 
المستخدم على اسم المؤلف للوصول إلى جميع البنود الأخرى لذلك المؤلف. 

> السماح بالوصول إلى كل بند مكتبي من خلال مسح كود تعريف ما.كما هو شائع مع معظم مكتبات هذه الأيامءفالبنود في مجمع هذه المكتبة لديها 
ملصقات أكواد تعريفية.والتي تخدم كمعرف وحيد ومفرد لكل نسخة لبند مستقل. 


<< 


بالإضافة إلى الكتب والبنود الأخرىءيدير البرنامج قائمة من الزبائن»"زبائن"المكتبة والذين يتم الترخيص لهم بتفحص(أو مراجعة) بنود المخرجات. لدعم 
التفاعل مع الزبائن»سيتضمن التطبيق هذه الميزات الخاصة بالزبون: 
يمكن للزبائن من مراجعة البنود دون مساعدة المدراء وأمناء المكتبة.,ءفبإمكانهم استخدام ماسح كود التعريف لمسح بنود المكتبة وكرت مكتبة 
الزبون وبنود المكتبة. 
يمكن أن يتم تفحص بنود الزبائن»ومراجعتها في فاتورة المكتبة. 
يتم إسناد رقم خاص" ۴|١‏ "لكل زبون والذي يتصرف ككلمة مرور. 
تحدد"أنواع الوسائط"لبند ما فترة (عائداته)أو مخرجاته ااه)عهمء (ولاحقا عملية إعادة تجدیده أو تحدیثه ا۷٥۸٥‏ ) 
يمكن للعملاء من عرض سجل المكتبة الخاص بهم»ومن ضمنه كل الكتب المخرجة حالياءوقائمة الغرامات المدينين بها للمكتبة. 
إذا رخص على بند معين»ءفبإمكان الزبون تحديث بند ما قد قام بمراجعته حديثا, 
المساعدة المركزية على الشبكة للزبون تكون متاحة من خلال المفتاح ۳1 القياسي .وملف المساعدة يتضمن معلومات غير الميزات الإداريةءمما 
يقلل مj‏ llتجريب experimentation‏ . 
٠‏ يمكن تقسيم الزبائن ضمن "مجموعات الزبائن"من أجل التقارير والمعالجات المريحة(المناسبة) لطاقم الإدارة.saff administrative‏ . 


من ضمن ال اء أمناء المكتبات»الهيئة الإدارية»وأشخاص آخرين بحاجة لإمكانية وصول متقدمة لميزات التطبيق.وهم المستخدمين الرئيسين للنظامءولیس 
العملاء يتضمن التطبيق ميزات خاصة بالمدراء التالية: 
ه توفر ميزة "تسجيل الدخولہاوه! " الوصول إلى الميزات الإدارية للتطبيق.يمكن فقط للمستخدمين المفوضين من تسجيل الدخول من خلال كلمة 
المرور المخصصة.وميزة تسجيل الدخول عادة تكون مخفية عن المشاهدة بالنسبة للعميل العادي. 
ه يمكن للمدراء من مشاهدة تفاصيل العملاء تماما كما يشاهدها العميلءولكن لديهم أيضا إمكانية الوصول إلى تفاصيل العملاء الإضافية.وعلى 
وجه التخصيص بإمكان المدراء إضافة عملاء جدد وإدارة ذاتيتهم وتفاصيل دراسية أو إحصائية.وبإمكان المدراء أيضاً تعطيل تسجيل عميل ما 
لمنع مخرجات بنود أكثر. 
ه يجمع ويدير المدراء الغرامات المالية وم۴ الخاصة بالعملاء»ومن ضمنها إمكانية إضافة غرامات غير قياسية أو صرف الغرامات غير 
المدفو عة unpaid fines‏ . 
ه يحدد المدراء سجلات كل بند والمدارة بواسطة قاعدة بيانات فاتورة النظام.وهذا يتضمن قواعد كل بند»مثل العنوان والمؤلفين. فكل بند يتضمن 
نسخة واحدة أو أكثرءوالتي تمثل البنود المادية والتي يمكن مراجعتها.ويتم إسناد أكواد التعريف للنسخ. 
o‏ إلى جانب البنود والنسخءيحدد المدراء جمیع القوائم والقيم المدعومة»ومن ضمنها أسماء المؤلفين والتصنيفات»قائمة أنواع الوسائط الناشرين› 
أسماء الكتب المتسلسلة»أكواد الحالة والتي تحدد ترتيب نسخة كل بندءوالموقع 
ه المدراء المختارين(الخصوصيين) بإمكانهم إضافةءتحديث »أو إزالة حسابات و آخرين.يتضمن كل حساب ميزة إعدادات تفويض خاصة 
(مجموعة الحقوق). 
ه بالإضافة إلى مسح أكواد التعريف»يمكن للبرنامج من مساعدة المدراء في تصميم وطباعة أكواد تعريف البنود والعملاء. 
ه تسمح عملية إدارة البرنامج البسيطة لهيئة الإدارة من معالجة البنود المتأخرة الدفع والغرامات بالاستناد على قواعد نظامية. 
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ه يسمح التطبيق من أن يتم إضافة العطل وحفظها,فعندما يراجع عميل ما كتاب »يضبط البرنامج تاريخ المستحقات للبند لتجنب العطل. 
ه يوفر مركز التعليمات الخاص بالإدارة مساعدة لتطوير ميزات التطبيق من خلال نفس المفتاح المتاح للعملاء. 
ه يتضمن التطبيق بعض التقارير الإدارية الأساسيةءوالمقدرة على ربط |١”‏ وںام“التقارير عند الحاجة في المستقبل دون الحاجة لتحديث البرنامج 


إلى جانب الميزات الأساسية للبرنامج التي تم اختبار ها بواسطة العملاء والمدراء يوجد العديد من المتطلبات الأخرى: 

« البرنامج سهل الاستخدام بالنسبة للمستخدم وسهل الاستعراض»وخاصة للعملاءءدون الكثير من التجريب والتدريب و”اأهجع ]أو المساعدة. 

. يخزن التطبيق بياناته في قاعدة بيانات مخدp .SQL Server database Jy‏ 

« نشر التطبيق يتم عمله بواسطة هيئة الإدارة والتي يكون لديها امتيازات إدارية محليةءلذلك فإن حزمة تنصيب ويندوز تكون كافية. 

« يستخدم تركيب(إعداد) التطبيق طرق 01 ×القياسية . 
ماعدا هذه المتطلبات العامة والميزات الخاصةءفقد عملت على منح تصميم حرءولكن من أين ستأتي قائمة المتطلبات؟إنها ستأتي من المستخدمين»أصحاب 
التطبيق.فهو يلبي احتياجاتهم_احتياجات زبائني»الذين سيستخدمون التطبيق يوم بعد يوم- وهذا ما يحدد قائمة من المتطلبات. 


بالعودة إلى أيام الكمبيوتر الأولىء »فلم يكن هناك مستخدمين»فمن يحتاج لمستخدمين؟للمستخدمين الكثير من الحاجيات»ومعظمها لايمكن سدها بواسطة 
الكمبيوتر .ولكن بالنسبة للتي يمكن عملهاءتأتي الحاجيات في خمسة أقسام: :البيانات والمعلومات»العمليات»إمكانية الاستخدام» العموميات»والحاجيات الخاصة 
بالمشروع .تتضمن عملية التصميم اختبار هذه الحاجيات والمراسلات الناتجة تجة عن هذه الحاجيات ضمن البرنامج المنتج .بتفحص البيانات الحالية 
والإجراءات» إجراء مقابلات مع المستخدم»وإتمام طرق استخلاص الحاجات الأخرىءفأنت تجمع التفاصيل التي تحتاجها لنحت الحل المناسب. 


N Bae E N E EVE E SN CC LE e N E 
يأخذون وقت طويل لكي ينسجموا تماما مع الكمبيوتر .فهم يحفظون معلوماتهم على 5-3 كروت تصنيف »أو لبادة أو لفافة ورقية أو مخطوطات ورقية أو ما‎ 
شابه»وبالتالي فلدیهم سبب ما للانتقال إلى الكمبيوتر كوسيلة تخزين: وهي أنه وسيلة مريحة. البيانات هي المعلومات الصرفة(المجردة)والمخزنة وبواسطة‎ 
برنامجك: أسماء»أعداد»صور »أو أي قيمة مستقلة قائمة بذاتها.أما المعلومات فهي البيانات في سياق:سجل الزبون »أو في ترتيب معين» مظهر‎ 
عندما توفر برنامج نوعي يرتقي بالبیانات إلى مستوى المعلومات»ءفأنت توفر مستوى مريح ومناسب‎ .) MEG 


عندما يطلب المستخدم استرجاع بياناته من الكمبيوتر ءفلديك ثلاث خيارات: 
# افراغ كل بايت مفرد من البيانات إلى الشاشةءالطابعةءأو الديسك»ءوتدع المستخدم يصنفهاءعملياء هذا هو النظام الذي لدى بعض المستخدمين قبل 
أن يبدؤوا باستخدام الكمبيوتر. 
#4 حماية البيانات من يتمكن المستخدمين من الوصول إليهاءبالتشديد أو الإصرار على تزويد كلمة مرور صحيحة أو تاریخ الانتهاءءأو أن تكون 
البيانات غير متاحة ولايمكن الوصول لها .من خلال "إلغاء الأمر»إعادة المحاولةءفشل".عملياءهذا هو النظام الذي لدى بعض المستخدمين 
الآخرين قبل البدء باستخدام الكمبيوتر. 
# جلب البيانات كمعلومات»على هيئة قابلية الاستخدام والوصول. 
على الرغم من أن كلا الخيارين الأول والثاني هما عمليا تجريبيان»ءفالخيار الثالث هو الأفضل.وكمية البيانات الممنوحة والتي من المحتمل أن يعمل تطبيقك 
على إدارتهاءفسیکون عليك توزیع التفاعل معها بت في كل مرةءوبتتابع مناسب.وهذه هي المعالجة sئعcه0/0.‏ 
من خلال تنفيذ معالجة محققةءفأنت تتحكم ليس فقط ببيانات المستخدم»ولكن أيضا التفاعل المنهجي مع البيانات. معظم المستخدمين بحاجة إلى مزود أو 
استخلاص فقط جز ء صغیير من البيانات كل مرة.ولكن عندما يعملون ذلك»فسیکون هذا ضمن سياق بعض المعالجات. على سبيل المتالء »فلشغل موقع أو 
مكان فالمستخدم:(1)يعمل على إدخال وتأكيد معلومات اتصال الزبون»(2)إدخال أو تحديث تفاصيل الطلب»و(3)يطبع أو يتصل إلكترونيا بمعلومات 
الطلب لکي يصبح تام فتطبيقك يدير هذه المعالجة للخطوات التلاث 


إذا كان برنامجك يحضر البيانات والمعلومات للمستخدم وبترتيب معين أو بطلب معين »ولكنه صعب الاستخدام فسيكر هك المستخدمين.وسوف يشمئزون 
atheه|‏ منك.وسينسجون قصص حولك»سواء كانت حقيقية أم لا. 
كمبرمج ءفإن عملك أن تجعل الكمبيوتر والبرمجيات التي تعمل عليهءقابلة للاستخدام قدر الإمكان.وعلى الرغم من عدم مقدرتك على التحكم بالعديد من 
الميزات الأساسية للنظام» ءفتبقى أنت الملك عندما يتعلق الأمر بالبرمجيات الخاصة بك .كلما كانت السهولة وقابلية الاستخدام في تصميم برنامجك» »کلما کان 
المستخدمين أكثر سعادة. ولكن يجب علي أن أحذرك»فكلما كانت السهولة أكبر للمستخدم كلما كان هذا يعني العمل أكثر على التطوير (البرمجة).دائما 
أقدم لك النصائح التالية فيما يخص أي برنامج: 
# لا تضع الكثير من المعلومات في نموذج واحد.وعندما ترتاب»أنقل بعض المعلومات إلى نموذج أخر. 
4ه قم بجلب المعلومات والبيانات الضرورية فقط للمستخدم بشكل افتراضي»واعرض المعلومات الإضافية فقط إذا طلبها المستخدم. 
أجعله سهل من أجل المستخدم لكي يصل ويحدث البيانات»ولكن اسمح للبرنامج اسمح للبرنامج من العمل بشكل مناسب دون الحاجة لهذه 
البيانات. 
4 استخدم النصوص ٠الصورءوالألوان‏ فيما ينفع المستخدم. 
4# بسط التطبيق بحيث تبدو مستندات المستخدم(مستندات المساعدة أو المعلومات)غير ضرورية. 
دائما وفر مستندات المستخدم.وأجعلها بسيطة بشكل كافي بحيث يصبح الاتصال من أجل الدعم الفني غير ضروري. 
هذه القواعد عامة وكافية للعمل مع أي نوع من التطبيقات»وهي من وجهة نظرك كافية بالنسبة لنا كمبرمجين وهامة لهم كمستخدمين. 
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تتطلع ئه ميكروسوفت باستمر ار لتجديد(الابتكار م/او٠٥””/‏ )»والمقدرة على الابتكار قد نقلت المنتجات البرمجية للأمام بخطوة هائلة.ولكن لسوء 
الحظ على المستخدمين إمكانية معاملة فقط الكثير من الابتكار كل مرة.بالنسبة للبرمجيات:فحتى مع البرامج المبتكرة والجديدة يجب المحافظة على بعض 
العموميات مع نظام التشغيلءوبما يتوافق مع البرامج الأخرى التي يتم تثبيثها على الجهازءوكما تتحدث مع المستخدمين حول احتياجاتهم وثفكر بأكبر تقدم 
في تقنية البرمجيات والتي ستعمل على توفيرهاءفلا تنسى العموميات. كما أنك لاتنسى المتطلبات الجو هر ية للمستخدمين:فلا تغمر المستخدمين بالطرق 
الجديدة لعمل المهام التي يفكرون بأنه يتم عملها بطرق تقليدية دائما يقومون بها بنفس الأسلوب»فما يحتاجه المستخدمون هو الاستقرار إ١‏ هأءأوممم في 
طريقة الأداء. 


يحتوي دليل هذا الفصل الملفات التالية- 
مستند. اتفاقية المشر وع Project Agreement. doc‏ 

هذا هو مستند المشروع الرئيسي والذي يحدد ميزات المشروع الكامل.وتحظى الاتفاقية بتمثيل كل من المطور والمستخدم.والخروج عن هذه الوثيقة يحدث 
من خلال معالجة"طلب التغير 0d٥‏ مو C٣‏ " فقط, 

Change 0r der. doc مستند.طلب التغیر‎ 

يتم استخدام هذا المستند لتعديل المشروع الأصلي من خلال معالجة "طلب التغير". عند استخدام هذه الوثيقةءفهي تتضمن و صف للتغير الذي يجب عمله 
على المشروع»وأي جدولة وتكاليف سوف تتأثر. 

Project Acceptance. doءع مستند.قبول المشرو‎ 

يتم استخدام هذه الوثيقة عندما يكتمل المشروع.والمستخدم جاهز لقبول المنتج النهائي.وهذا المستند يضم عناصر"اختبار معيار القبول Acceptance‏ 
Criteria esti n9‏ "و"قبول المشروع" المشروحة مسبقا في هذا الفصل. 

زلك الحرية الثامة في استخام هذ التق لدعم مشروعك الخاضن, 
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تصميم فاعدة |lئlنlت Designing the Database‏ 
إذا كان لديك بیانات فتحتاج لوضعها في مكان ما.وهل هناك مكان أفضل من وضعها في قاعدة بيانات؟قاعدة البيانات هي تجمع من 
البيانات المنظمة لسهولة | بواسطة الكمبيوتر. 


تعمل قواعد. البيانات العلائقية على تحمیع البيانات في جداولیع/bھا‏ »وکل منها يخزن مجموعة خاصة من السجلات /e ٤0/۵۶‏ غير 
المرتبة. .من أجل الراحة»يتم إحضار الجداول كشبكة من قيم البيانات»حيث ان کل صف r0۷‏ يمثل سجل وحيد وکل عمود column‏ 


يمثل حقل 2//ثابت والذي يظهر في كل سجل.يمثل الجدول التالي جدول طلبيات»مع سجلات منفصلة السطور فكل سطر يمثل 


»ومن e‏ ترتیب النتائج بالاعتماد و گنود معين e‏ الحظ .هذا الحدول من الطلبيات لدیه ME‏ من 
أسماء الزيائن المكررة وأسماء المنتجات 8808 تتكرر أيضاً عدة مرات. ويالإضافة إلى معرف اسم المنتح 
1D‏ ductهام»‏ فيشير 8٤۷01٥0۴‏ إلى قهوة»وواحد من أسطر القائمة يشير إلى شاي.والعديد من المشاكل تكون ملازمة 
للبيانات الموضوعة في ملف ١/١‏ ۸/2 وحيد لجدول قاعدة بياناتعاطةا عمءةطةاهةك .وبالتالي كان الحل فيما يسمى بالتطبيع " 
a//zationص0rmم‏ ".وذلك بتقسيم البيانات ضمن جداول منفصلة مع مجموعات جزئية من البيانات»يؤدي إلى إسناد معرف 
وحید ومفرد لکل ۲٠۰٥۲۵/۲٥٣۷‏ سجل/صف في كل جدول (مفتاح رئيسيرع» 2/۷/// هة )وعمل العديد من التعديلات 
الأخرى»ويمكن أن يتم تطبيع البيانات من أجل كل من فعالية المعالجة وتكامل البياناتراااوعا١|‏ دة .فمن اجل الطلبيات 
البسيطة في الجدول السابق يمكن أن يتم تطبيع البيانات ضمن ثلاث جداول منفصلة: واحد من أجل بنود أسطر 
الطلبيات»وجدول أخر من أجل الزيائن»وواحد أخر من أجل المنتجات كما في الجداول التالية وعلى الترتيب 
yاeاctiعمespا.ففىي‏ كل جدول قمت بوضع علامة نجمة )كأا#ائج بجانب عنوان العمود الذي يتصرف كعمود مفتاح رئيسي. 


فلضم البيانات من جداول متعددة مباشرةءاريط(أوصل) الحقول المتطابقة.على سبيل المثال»يإمكانك وصل حقل 10 ۳۴۲ 0اا في 
جدول البنود المسطرة مع حقل المفتاح الرئيسي في جدول الزيائن.حالما يتم الربط فتفاصيل سجل بند سطر مفرد مربوط يمكن 
جلبه بواسطة الربط الكامل لأسم الزبون ١٣#‏ ١08لا‏ .وهو نفسه بالنسبة للربط المباشر مع أي جدولين والذين لديهما حقول 
قابلة للربط أو الوصل.يبين الشكل التالي العلاقات الخطية بين جداول الزبون ٣٥۲‏ 0أكلء »والمنتجاع لهام .و الطلبية ٥٣ا‏ 0۲۲ . 


Line Items 


Customers Record ID Products 
Customer ID Order ID Product ID 
Customer Name Customer ID Unit Price 


Product ID 
Quantity 


يبين الشكل ثلاث جداول مرتبطة ولكن ماتزال تعمل كأنها جدول مفرد. 
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لربط الجداول ببعضهاءتنفذ قواعد البيانات العلائقية لغات الاستعلام sموةuو”‏ ةا ر/عرا¶ التي تسمح لك من معالجة البيانات باستخدام 
الجبر العلائقية/(عو/ة /0۸2ا2/€/ (والذي اشتق منه مصطلح قاعدة البيانات العلائقية)ءوالأكثر شيوعاً لهذه اللغات هي .السكول 
ا٩ء‏ والتي تستخدم اللغة الانكليزية البسيطة مثل الجمل للربط والترتيب»التلخيص» واستخلاص قيم البيانات التي تحتاجها 

تماماً. والعبارة الرئيسية»هي "اختر 5٤1٤٣‏ ".والتي توفر اختيار بيانات قاعدية واستخلاص الميزات.ويوجد أيضاً ثلاث عبارات أخرى 
مشتركة وهي»إدراج 15٤۸۲‏ .تحدیث٤‏ ۲0۸۲لا وحذف 0۴1۴۳٤‏ ,»تسمح لك هذه العبارات من معالجة السجلات المخزنة في كل 
جدول»فمع بعضها كل من هذه العبارات الأربع تكون :أوامر لفة معالجة البيانات (0×1) ta Man /pu/ 2ا0٣ 12929٤‏ الرئیسیة 
لسکول ا5 . 

تحتوي سکول أيضاً على عبارات لغة تعريف البيانات(ا00) eوة9uہ‏ ةا da de ti0"‏ والتي تسمح لك تصميم الجداول المستخدمة 
لحفظ البيانات. بالإضافة إلى ميزات قاعدة البيانات الأخرى.وسأريك أمثلة عن عبارات سكول المتنوعة فيما بعد في هذا الفصل. 

تبسط الأنظمة الخاصة للبيع Vendor-specific systems‏ متل خادم میکروسوفت سکول 587€ Mir 050۴5 5Q1‏ وأور Oracle's JI‏ 
02c‏ وميكروسوفت أكسس ۴55ء٥۸‏ ك'ا0۴كهMi‏ الميزات الجوهرية لكل من ا0٥2و‏ امن خلال تحليل إضافي للبيانات وأدواتها 


الإدارية. 
وتكافح هذه الأنظمة مرة أخری على ميزات هامة مثل تكرار البيانات ٥ ٣‏ تامع هاه .تكامل البيانات المقاومة للانھيار crash-proof‏ 
inte ri‏ data.السرعة‏ التی ز الاستعلامات المعقدة على استرجاع النتائج المطلوية»ومن لديه أكبر تدفق خاص. 


إن اداة قاعدة البيانات الرئيسية على مستوی العمل لمیکروسوفت هي سکول سرفر5€۲۷8۲ SQL‏ .وهي على خلاف میکروسوفت 
أكسس(منتج أخر معروف لقواعد البيانات العلائقية من إصدارات میکروسوفت والذي أت مع مجموعة أوفيس)» »يتضمن سکول سرور 
إدارة بیانات ومیزات تحليل متقدمة. 

إن الصفات الغالبة الآن على جميع إصدارات الفيجوال أستوديو احتواءها نسخة ما من سكول سرفر»حتى تلك الإصدارات 
المنخفضة(المتمات).فبإمكانك استخدام سكول سرفر ضمن تطبيقات الدوت نت الخاصة بك.ولكن سكول سرفر2005 اليوم يتيح لك 
نحت(صناعة) الإجراءات المخزنة المضمنة باستخدام كود الدوت نت»على طول مع لغة المعالجة الإنشائية و١‏ |اامriعsء‏ LاSQ-1‏ 
eوuaوn‏ ها الأصلية التقليدية. 1 

اسم السکول سرفر 586۲۷۴۲ 5Q1‏ يدل ضمنياً كمنتج "خادم۲٥۲۷عء‏ ".فهو يعمل في خلفية النظامء ويتصل معك انت المستخدم .فقط 
بامتلاكك على شبكة عمل 6۷0۲۸" قياسية يتم تأسيسها لأول مرة كااطهائe fit‏ متصلة مع محرك الخدمة ٤٣9٣ع e۲‏ erك.وهذا‏ 
صحيح حتى ولو كان محرك خادم سكول مشغل على جهازك الخاص.فترقب منتج السرفر مثير كما هو الحال بالنسبة لقراءة كتب 
التدريس المتخصصة )00ط اهاهاا بالفيجوال بيسك2008 الأخرى والتي تتجنبها على نحو واسع»ءلذلك فان میکروسوفت توفر أدوات 
عميل متنوعة تتيح لك إدارة قواعد البيانات» الجداول» وخاصيات قاعدة البيانات الأخرى.بالنسبة لي لم أثبت ُي من إصدارات السكول ما 
عدا الأدوات التركيبية التي يتم تنصيبها مع نسخة الفيجوال أستوديو2008 الاحترافية. 

على الرغم من ذلك ماتزال ميكروسوفت مستمرة في تحديث وبیع میکروسوفت أكسس» :ومن الموصى به أكثر وأكثر من أجل 
المطورين المحترفين استخدام وتوزیع قواعد البيانات قي هيئة مخدم سکول .وحتی أن میکروسوفت ترخص لك إعادة توزیع سکول 
سیرفر2005 بطبعته السريعة مع تطبيقك. ولعمل هذاءعليك أولاً امتلاك "ترخيص سكول سرفر2005 بطبعته السريعة والقابلة لإعادة 


التوزيع" من ميكروسوفت.ولحسن الحظ فهِي مجانية ويمكنك امتلاكها من موقع الانترنت التالي: 


http:{/www.microsoft EERE 


تولي العمل في اليابان سهل جدآءبمجرد إتقانك اللغة.ونفس الكلام صحيح فيما يخص خادم سكول :فهو سهل جدآً من أجل معالجة 
وإمكانية الوصول للبياناتء حالما تتقن اللغة .ولكن في هذه الحالة »اللغة هي سكول ا5 .أو لغة الاستعلام الهيكلية ٥4d‏ ں٣5‏ 
Query Language‏ .فلقد أصبحت سكول المعبر القياسي في صناعة قاعدة البيانات. 

يشرح هذا الفصل عبارات ا00و ا0۷والتي هي أكثر منفعة بالنسبة لتطوير برنامج المكتبة.وستكون مسرور لمعرفة أن سكول 
ليست بهذا الحرص ٤K‏ ام‌الكبير فيما يتعلق بهيئة العبارات المتنوعة.حيث أن الفروقات في حالة الأحرف الكبيرة والصغيرة -#€۲م ملا 
and lowercase distinctions‏ يتم تجاھلها.»ف ۲٤٤۴ا5۴1هي‏ نفس اءe‌اعءونفس‏ ا٣5e1€.(‏ كود (1-5@1 ) diti" 5Q1‏ سکول 
التقليدي يكون على الأغلب في الحالة الكبيرة)وإني استخدم الحالة الكبيرة من أجل كل الكلمات المحجوزةء والحالة المدمجة من 
أجل الجداول كعاطهاء الحقولءلاعا؟ » والبنود الخاصة الأخرى. 

مهما يكن فإن من المهم الثبات على منوال واحد.وإن توظيف المحارف الخاصة whitespace‏ (مثل الفراغ»أو أي محارف لاتظهر في 
الطباعة) يعود إليك وكما تراه مناسب.فيمكنك وضع عبارات في سطر واحد طويل .أو وضع كل كلمة في سطر مفرد.الحالة الوحيدة 
التي تكون فيها المحارف الخاصة وحالة الأحرف(كبيرة أو صغيرة)مسألة مهمة في المتغيرات النصية للبيانات النصية الفعلية»فما 
تكتبه» هو ذلك الذي يبقی. .تنتهي عبارات سكول عادة بالفاصلة المنقوطة onاsemico.ولکن‏ بعض الأُدوات لاتتطلب إدخال الفاصلة 
المنقوطة٣٥اہsemic‏ »وأدوات أخرى تتطلب أن تضمنها.عندما تستخدم أدوات العميل المرئية لسكول سرفر(إدارة أستوديو وإدارة 
أستوديو السريع)فإن الفاصلة المنقوطة اختيارية»ولكن من الجيد تضمينها عندما تستخدم عدة عبارات مع بعضها البعض»ءعبارة بعد 
عبارة.وعبارات سكول المستخدمة في كود الفيجوال بيسك لا تتضمن أبداً الفواصل المنقوطة.فيما بعد عندما تنظر إلى صيغ سكول 
اماع اQكالتي‏ كتبتهاءستلاحظ الكلمة 60مرة بعد مرة»في السكول سرفرءهذا الأمر يقول"من أجل جميع العبارات الأخرى التي 
تظهر حتى الآن. تقدم للمام وeلجlq "For all of the other statements that ijÎJ|‏ 


. "appeared so far, 2 ahead and i them now.” 


من المحتمل ان تكون هذه صدمة لك»ءولكن قبل ان تخزن أي بيانات في جدول»عليك أن تعمل على إنشاء ذلك الجدول.سكول لديها 
الأداة التامة لعمل هذا:عبارة "إنشاء جدول٤‏ |۲۸81 ۴ R٤۸۲‏ ".فهي عبارة من العديد من العبارات .والقواعد الأساسية basic syntax‏ 
بسيطة جداآً: 

CREATE TABLE tableName 
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( 


fieldName1 dataType options, 
fieldName2 dataType options, 
and so on... 


) 

فقط اعمل على ملىئ الأجزاء وستكون جاهز لتعبئة (البيانات »وهذا كل مافي الأمر) .أسماء الحقول والجدول يتم بناءها من الحروف 
والأرقام بإمكانك تضمين فراغات ويعض المحارف الخاصة»ولكن يتم عمل هذا من أجل کتابة کود فقط فیما بعد ستری.فکل بائع لدیه 
مجمع خاص من أنواع لبياناتیئع‌مyا‏ اك . سأقتحم إصدارات سكول سرفر هنا.يسمح لك 0010۸5 من تعیین أشياء مثل فيما إذا 
يتطلب الحقل بيانات ههل أم لاءوفيما إذا يمثل المفتاح الرئيسي للجدول أم لاءوقيود كا٣أة/ائ”0ء‏ أخرى مشابهة.الامتدادات 
Extensions‏ للترکیب تتیح لك تثبيت القيود كا١‏ أة۲†كه» التي تطبق على كامل الجدول.الفهارس كع×726/ (التي تسمح لك ترتيب أو 
البحث بعمود معين بسرعة أكبر)»وتفاصيل تخزين البيانات. 
إليك مثال عن عبارة "إنشاء جدول" والتي يمكن استخدامها لجدول بنود اسطر الطلبية €, ذا ۲٥۲‏ . 

CREATE TABLE Lineltems 


( 

RecordID bigint IDENTITY PRIMARY KEY, 
OrderlD bigint NOT NULL, 

CustomerID varchar(20) NOT NULL 
REFERENCES Customers (CustomerID), 
ProductlD varchar(20) NOT NULL, 
Quantity smallint NOT NULL 

) 


الكلمة المحجوزة N۲1۲۷۲١E٤10تسمح‏ لخادم سكول SQ) S۲۷٥۲‏ من تولي مسؤولية تعبئة حقل ۸6٨0۲۵10‏ بالبيانات» وسوف تستخدم 
العداد التتابعي C01١8‏ اةاأممuوهء‏ لتزويد قيمة مميزة ومفردة ل 6٤٥0۲۵10‏ ۸بالنسبة لكل سجل جديد.التعبير "مفتاح رئيسي 
PRIMARY KE‏ " يعرف الحقل ٤0۲۵10‏ ۸€كقيمة تعريف مفردة ومميزة بالنسبة لكل سجل في الجدول .أنواع البیانات ٣۲‏ أواطاو 
int‏ aصsتشیر‏ إلى الحقول التي تحفظ قيم عددية ذات حجم مناسب»والنوع ۸3۲٥۷3۲يوفر‏ مساحة لأجل النصوص »بالطول الأعظمي 
المخصص في الأقواس(۲5٤٤٤‏ ۸2۲2 20). يعرف التعبیر ۸٤۴٤۸٤۸٣٤5‏ العلاقات بين جدول ۳۶٤1ع"‏ اوجدول أخر مسمى 
customers‏ تطابق القيم في حقل ۴۲10" 0اus٣.1temsعinا‏ القيم المفتاحية من حقل "٤۲10‏ ers.Cust0مCustom.‏ (لاحظ ترکیب 
"النقطةاهل " لفصل أسماء الجداول والحقول.وهي تظهر في كل مكان في السكول)المرجعيات(العلاقات كعء١۸6۴6۲6)‏ بين الجداول 
تعرف أيضاً علاقات(مرجعیات) أجنبية(أو ما یطلق عليه مفتاح ثانوي) 5ئ€٥۸‏ €€€ ۸ 0۴€/9/ . 
إذا كنت ترد جعل هيكل أو خيار التفيرات لجدول أو حقوله بعد أن يتم إنشاءه» تتضمن گل عبار RI TER TAÊ‏ والتي یمکنھا 
تغير تقريباً كل شيء في الجدول.ويوجد أيضاً عبارة f DROP TABLE‏ التي تستخدم للتخلص من الجدول وكل بياناته.ومن المحتمل 
انك تتجنب هذه العبارة على البيانات الموجودة في المنتج»وكمستخدم تميل للغضب قليلاً عندما تختفي فجأةَ جميع بياناتك. 

خص الجدول التالى أنواع البيانات المتاحة في مخد .SQL Server J‏ 


8-بايت(64-بت)لحقل عددي صحيح للقيم التي تتر اوح من9,223,372,036,854,775,808- 
إلى9,223,372,036,854,775,807 


تدعم ثلاث قیم ممكنة:1,0 أو بدون قيمه اا0 N.بشکل‏ عام تستخدم للقيم المنطقيةہaءامه8‏ .ذاتياًءیخزن السكول 
سرفر عدة حقول بت لسجل مفرد في حقل عددي صحيح مدمج. 


Cursor‏ یستخدم هذا النوع من البيانات ضمن الإجراءات المخزنةومur YJ y« stored proceed‏ یتم استخدامه لإنشاء عمود. 


حقل بتدريج عشري وتابت الدقة.إنك تحدد العدد الأكبر من الأرقام التي تظهر على جانبي النقطة العشرية 
)llئدقprecision‏ ( والعدد الأكبر لهذه الأرقام لے یمکن أن تظهر کے الجهة اليمنى للنقطة أو 

الفاصلة العشرية ممم اجاعمك (التدريجماهءء ).على سبيل المثالءوضع (10,4)اi2ءمهيعمل‏ على إنشاء حقل 
حتى عشرة أرقام بالكاملءوأربع منها يمكن أن تظهر بعد الفاصلة أو النقطة العشرية.وقيمة الدقة الأعلى هي 38.و 
Jaenumeric‏ !كف .dec Jün«decimal İsynonym‏ 


decimal, numeric 
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نوع البيانات هذا جديدءفي السكول سرفر 2008ءويدعم الاستعلام الهرمي(التسلسلي)رالبياتات القجرية 
الشكل(الهيئةعادك ١ممة١ء-هعع)‏ ).وهي غير متاحة في سكول سرفر2005. 


Hierarchyid 


حقل عددي صحيح 4-بايت(32-بت) للقيم ضمن المجال من2,147,483,648- إلى2,147,483,647 


rowversion, timestamp‏ یتم استخدام نوع البيانات هذه لتسجيل أحداث التعديل المطبقة على السجلات.ويوجد قيود على استخدامهاء»و هي غير 
مضمونة لأن تكون مفردة ومميزة ضمن الجدول. مصهاءم ماهو مكافئ قليل الأھمیة deprecated synonym‏ 
rowversion»استخدم‏ ہrowversioبد‏ عنە. 


حقل(متغير) عددي صحيح 2بايت(16بت) للقيم التي تتراوح من 32,768- إلى 32,767 . 
نوع عام يخزن القيم للعديد من أنواع الحقول المخصصة الأخرى. 


حقل عددي صحیح دون إشارة لاعا؟ rمومint unsigned‏ 1بایت(8بت) لمجال القیم من إلى 255. 


› بيانات ثنائية متغيرة الطول»حتى 8000بايت في الطول.إنك تحدد الطول من خلال الو سيطءع†مص هام‎ Varbinary 
agg SS 
له مثل (×ھ )رہاط هیتیح مدخلات حتی 2بلیون بایت تقریباً.‎ 


.2 68 توفر التخزين لمستندات(وثائق)بیانات ا۷ ×المرمزة ١٥م رإوالغیر مرمزة dەمر†ہں »حتى 2غيغابايت‎ Xm 
تضيف العبارة ۸۲٤1۸N5سجلات(صفوفكل۲٠ء٠۲ )بيانات للجدول .يتم إضافة البيانات هة( للجدول سجل واحد كل مرة .(تنوع عبارة‎ 
يتيح لك إدخال عدة سجلات .ولكن هذه السجلات يجب أن تأتي من مصدر آخر لجدول موجود) لاستخدام عبارة‎ N 5E۸آ‎ 
الجدول والحقول المقصودة ومن تم القيم المستقلة التي يتم وضعها في کل حقل .کل قيمة للبيانات تتوافق مع کل‎ ددح.INSERT‎ 
اسم عمود بیانات محدد.‎ 
INSERT INTO Lineltems 
(OrderlD, CustomerID, ProductID, Quantity) 
VALUES (10002, 'BW3', 'BEVO1COF', 1) 
المكتوبة سابقا »سيعمل إجراء الإدخال هذا على إضافة سجل جديد لجدول ء”#اامأامع خمسة‎ R۸۴ ۳ ABاٌ٤ خذ هذه العبارة بالمقارنة مع عبارة‎ 
حقول (أو أعمدة)جديدة-أربع حقول معينة »ءزائد حقل المفتاح الرئيسي ره) راهم الذي يتم إضافته بشكل آلي لحقل ٥ا۲۵ه٥هR (حيث أنه تم تعليمه‎ 
).يعمل سكول سرفر اختبار تكامل البيانات المتنوعة بالنيابة عنك.كل حقل بيانات تعمل على إضافته يجب أن يكون من نوع البيانات‎ N۲۱۲۲ كمعرف‎ 
على علاقة مع جدول امہ ماوں٥»ءسيفشل الإدخال إذا كان 8۷۷3غير موجود سابقا في جدول‎ Cںوا٥٣‎ ٥۲٥ الصحیح, ہما أننا قمنا بتصمیم حقل‎ 
.Customer 
الحرفية العددية يمكن أن يتم تضمينها في عبارات سكول عند الحاجة دون أي شرط أو قيد إضافي.الحرفية النصية هي دائما تكون محاطة بعلامة‎ 
|هذه.وإذا أردت أن تضمن علامة تنصيص‎ N56۸١ تنصيص(اقتباس) مفرد»كما تم عمله لمعرفات حقول 6۲" 0اءاعر عله مفي عبارة الإدخال‎ 
مفردة في الحرفيةءقم بإدخاله مرتين:‎ 
'John O"Sullivan' 
ا) بعلامات تنصيص مفردة:‎ "٠ قم بإحاطة البيانات الحرفية او١6]اوالقيم الزمنية ومںاج۷‎ 
'7-Nov-2005' 
. مثل قيم التاريخ والوقت هذه تقبل أي تنسيق مميز »على الرغم من أنك ستستخدم تنسيق ليس من السهل على سكول سرفر أن يسيء تفسير 6إ مه”أءا"‎ 
العديد من أنواع الحقول تدعم قيمة "غير مسندةd ع ssigھےہu "»قيمة تشير أن الحقل لا يحتوي بيانات على الإطلاق.مثل هذه القيم تعرف "بدون قيمة‎ 
ااام "»ويتم تخصيصها في سكول سرفر باستخدام الكلمة المحجوزة "بدون قيمة اال" ".ولا يمكنك إسناد قيمة "بدون قيمة ال" " لحقل المفتاح‎ 
.N07 NULL الرئيسي»أو لأي حقل تم تعليمه بالخیار‎ 
:DELETE لإزالة سجل تم إضافتها سابقاءاستخدم عبارة‎ 
DELETE FROM Lineltems WHERE RecordID = 92231 


الفصل الرابع:تصميم قاعدة البيانات 76 mhm‏ 


تتضمن عبارۃة DE1 E۲۴٤‏ الشرط(أو التعبير WHERE‏ حيث)(الجز ء 92231 = Record|D‏ WNHERE).يسمح‏ لك الشرط ع۷16۸ من الإشارة إلى سجل أو 
أكثر في جدول ما وذلك بعمل مقارنة مع بيانات الحقول.ویمکن لشرط ع۷1۸ آن يتضمن کلمات محجوزة ۸۸0و 0۸لربط عدة شروط وأقواس 
parenthesesللتجمیع.‏ 


DELETE FROM Lineltems WHERE OrderlD = 10001 
AND ProductlD = 'BRDOSRYE' 


يمکن لمثل عبارة 2۴1۴۲۴ هذه أن تحذف 0سجل»سجل واحد أو1000سجل.ولذلك فإن الدقة في شرط ۸٤‏ ۴٣۷١هام‏ جدا.لحذف 
جمیع السجلات في الجدول قم بإخراج شرط بالكامل W۴۸۴‏ . 
DELETE FROM Lineltems‏ 
تستخدم عبارة "تحدیث ۴0۸۲۴ل " أیضاً تعبیر 1۴۸۴ /لتعديل القيم في سجلات جدول موجود. 
UPDATE Lineltems‏ 
SET Quantity = 4‏ 
WHERE (RecordID = 92231)‏ 
يتم عمل الإسنادات للحقول بالتعبير "ضع 5٤١‏ ".ضع اسم الحقل(ا٤/Q13)على‏ الجهة اليسارية من إشارة المساواة »والقيمة 
الجديدة على الجهة اليمنية من إشارة المساواة(4).ولإسناد عدة قيم في نفس الوقت»افصل كل إسناد بالفاصلة ۳2 00۳.وبإمكانك 
أیضاً تضمین صیغ 5ھاu ۴0۲٣‏ وحسابات۸5 0٥‏ tھاcuاca‏ . 


UPDATE Lineltems SET Quantity = Quantity + 1, 
ProductlD = 'BEVO2POP' 
WHERE RecordID = 92231 


وکما مچ عبارة 0۴1۴۲۴ »فيمكن لعبارة 0۸1۴٥لاأن‏ تحدث صفر سجل»سجل وحيد»أو عدة سجلات بالاعتماد على أي سجلات 
تتطابق مع الشرط .NHERE‏ 1 
العبارة الأخيرة للغة معالجة البياناتا“0 .والأكثر استخداماً هي عبارة "اختر S۴٤1۴٤٣۲‏ ". 
SELECT ProductlD, Quantity FROM Lineltems‏ 
WHERE RecordID = 92231‏ 


تقوم عبارة ۲٤۴ا٤5بعمل‏ مسح على جدول(5٠ ٣٤1۴‏ 1ا)ء والبحث عن جميع السجلات التي تطابق المعيار المقدم( = 10١0۲٤عR‏ 
91)وتعود بأصغر جدول يحتوي فقط الحقول المشار إليها (120اucههrا۴» )Quantity‏ للسجلات المتوافقة.والاستعلام الأكثر عمومية 
والذي يعود بكل الصفوف(السجلات) والحقول(الأعمدة) هو التالي _ SELECT * FROM LihêItêَmhS‏ 
يعود هذا الاستعلام بجميع السجلات من الجدول 6165 "] بدون أي ترتيب معين. وتعني .5أ8۲كه النجمة(*) تضمين كل 
llلحaوfields.”J “include all‏ 
يعود الشرط "ترتيب بوا طة 8۷ ORDER‏ " بنتائج مرتبة بطريقة خاصة(معينة): 

SELECT * FROM Lineltems 


WHERE Quantity > 5 
ORDER BY ProductlD, Quantity DESC 


يعود هذا الاستعلام بجميع السجلات التي تكون فيها قيمة حقل ۷ان† ٣ة Qu‏ أكبر من 5»ويرتب النتائج أولاً بواسطة عمود ProductID‏ 
(بترتيب تصاعدي۴۲٤‏ 0۲۵ 5٤8١١9‏ )ومن تم بواسطة حقل ذو القيمة العدديةYاا† uan‏ ricمصumہ‏ (بترتیب تJjliي in descending‏ 
اrdeاo.وذلك‏ من خلال كتابة الكلمة .)0٤5٣‏ 
تتيح لك دوال الإجمالي (التراكم)5 ٣٥ں‏ عatوeاووA‏ وميزات التجميع ٣٥5‏ اع وinمouاو‏ تلخيص النتائج من مجموعة أكبر من 
البيانات.يوتق الاستعلام التالي الكمية المطلوبة الإجمالية ti†yاquan ordered‏ اtota‏ لكل منتج اucلdهام‏ في الجدول: 
SELECT ProductlD, SUM(Quantity) FROM Lineltems‏ 
GROUP BY ProductlD‏ 


بامكانك استخدام ٥/٣5‏ زلربط البیانات مع بعضھا من جدولین. مميزين أو أكثر. الاستعلام التالي يضم جدول ء"اآع”أاوجدول 
customer‏ على أعمدتهم ۲10عمtomاCus‏ المتطابقة .وتوضح أيضاً عبارة abbreviations ٽlرlصڏتخ| مlدختسا ەذھ5٤1 ٤٤°‏ 
الجدول(السابقات 1ا و لا٣)المضافة‏ من خلال التعبير 45»وهي ليست ضرورية عادة»ولكنها تساعد على جعل الاستعلام المعقد أكثر 
قابلية للقراءة: 
SELECT LI.OrderlD, CU.CustomerName, LI.ProductlD‏ 
FROM Lineltems AS LI INNER JOIN Customer AS CU‏ 
ON LI.CustomerlD = CU.CustomerlD‏ 
ORDER BY LI.OrderlD, CU.CustomerName‏ 
يستخدم هذا الجدول "الربط الداخلي"٣‏ اهز in٣‏ "وهو واحد من خمسة أنواع للربط»وكل منها يعود بمجوعات مختلفة من السجلات 
بالاعتماد على العلاقة بين الجدول الأول(اليساري) والجدول الثاني(اليميني)في الربط "أ0ز. 
الربط الداخلي Inner joi:‏ 
يعود فقط بالسجلات التي تتطابق مع بعضها في الحقول المربوطة.وهذا النوع من الربط يستخدم الكلمة المحجوjزةö „INNER JOIN‏ 
الربط الخارجي اليسار ي : Left outer join‏ 
يعود بكل سجل من الجدول اليساري وفقط بالسجلات المطابقة من الجدول في الجهة اليمنية من الريطءفإذا كان سجل الجدول 
اليساري لیس لدیه تطابق.فإنه يتصرف وکأن جميع حقول الجدول اليميني لذلك السجل تحتوي قيم "بدون قيمة ا الا" ".هذا النوع 
من الربط يستخدم الكلمة المحجوزة 301۸ ١1۴۴.وأحد‏ استخداماته يمكن أن يكون لربط جدول LineltemsJsı>gProduct‏ .فبإمكانك 
إرجاع قائمة بكامل أسماء المنتجات لكل المنتجات المتاحة .بالإضافة إلى الكمية الإجمالية المطلوبة من كل منتج 
بوضع جدول المنتجات اع uاك١ه۴۲على‏ الجهة اليسارية من الربط الخارحجي اليساري"ˆ اهز ٣٥اه‏ اعا .قإن ااا سیعود بأسماء کل 
المنتحات»حتى ولو كان ذلك المنتح لم يتم طلبه على الإطلاق(ولا يظهر في جدول ١٣1۴ع‏ آا), 
الربط الخارجي اليميني Right ouثer joi‏ 
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يعمل هذا تماما مثل الربط الخارجي اليساري»ولكن جميع سجلات الجدول اليميني يتم استعادتهاءواستعادة فقط سجلات الجدول 
اليساري التي لديها تطابق. ويستخدم هذا النوع من الربط الكلمة المحجوزة .RIG H٣ J01۸‏ 

Full outer join الربط الخارجي الم‎ 

يعود بجميع السجلات من الجدولين اليساري واليميني»فيما إذا كان هناك تطابق أم لا.عندما يوحد تطابق»فإنه يتم عكس النتائج كا أ 
in the results‏ ectedاfعا.وهذا‏ النوع يستخدم الكلمة الnحجوjزةö .FULL JOIN‏ 

الربط المتقاطع(المتصالب )ز٥ز Cross‏ 

ويدعى أيضاً الربط الديكارتي”أهز ٤2/65/27‏ (دمج مجموعتين لتوليد مجموعة واحدة مدمجة).ويعود بكل السجلات المدمجة الممكنة 
اليمنية واليسارية.ويستخدم هذا النوع الكلمة المحجوزةö .CROSS JOIN‏ 

يركز الربط على العلاقة التي بين الجدولين.(وهذا الاستخدام ل"العلاقة" ليس الأساس لمصطلح قاعدة البيانات العلائقية /ق١0/ااع/‏ 
t€‏ )عض الجداول توجد في علاقة "أباء- أبناءلاا-ا”eإمم‏ ".فسجل واحد "ر ب"لدیه واحد أو أكثر من السجلات الأبناء المعتمدة 
في جدول أخر. وهذا غالبا صحيح للطلبيات6۲5 ل0۲ ."فعنوان طلبية۲٤‏ ل2م" d€‏ "مفرد لدیه عدة "بنود اُسطرک"۴ )| عا "وهذا النوع 
من العلاقة يعرف بواحد-إلى -العديد one-to-many‏ »حıیث‏ أن سجل واحد يكون مرتبط بعدة سجلات في جدول أخر.والعلاقة 
تكون أحادية الاتجاه» والسجل الابن المعطى لايرتبط بسجلات أبوية متعددة. 

تربط العلاقة واحد-إلى -واحدع”0-0-0/7€ سجل وحيد في جدول واحد إلى سجل في جدول أخر.وهي بسيطة جدآ»وتستخدم غالبا 
لتحسين القيم الموجودة في السجل الأصل من السجل التكميلي في الجدول الثاني. 

في علاقة عديد - إلى -عديدر"78/7۷-0-3/ » سجل مفرد في جدول واحد یکون مصحواً مع عدة سجلات في الجدول 
الثاني»وسجل مفرد في الجدول الثاني يكون أيضاً مصحوياً بعدة سجلات في الجدول الأول.ومثال حقيقي عنه .العلاقة بين المعلمين 
والطلاب في وضع كلية ما.فمعلم واحد لديه العديد من الطلبة في الصف (الحجرة الدراسية)ولكن كل طالب أيضاً لديه العديد من 
المعلمين في كل فصل دراسي ۲ع€أكئ6"عS.‏ 

يتطلب التنفيذ التطبيقي لعلاقة عديد-إلى -العديد عملياً ثلاث جداول:الجدولين المرتبطين »وجدول "وسيط بينهما" عع سامط-مg‏ " 
الذي يرر بعض.وساريك متال لمثل هذا الجدول في المقطع التالي من هذا الفصل. 


العبارات البسيطة التي جدولتها هنا تعالج موضوع إمكانيات معالجة البيانات المتاحة بشكل سطحي ع٤هfا‏ اء scratch the‏ من خلال 
سکول.ولکن حالياً يمكن أن تكون قد لاحظت e‏ سکول يحاكي اللغة الانكليزية في القواعد(التركيب) على نحو رائع»وحتى أكثر مما 
هي عليه الفيجوال بيسك.في الحقيقة الاسم الأصلي للغة ا٤ل‏ والذي كان تركيب ل"لفغة الاستعلام الانكليزية الهيكلية 
Structured English Query Language‏ " وبما أن عبارات سكول قد أخذت بالتعقيد أكثر»فستبدو أكثر شبهاً لمجموعات عشوائية من 
الكلمات الإنكليزية. 

الهدف هنا هو تقديمك للتركيب ا لعبارات سكول. معظم العبارات التي سنواجهها في مشروع المكتبة لن تكون أكثر تعقيدآً من 
العبارات التي تم تضمي: ة هنا. 


یمکن للفيجوال بيسك أن تتفاعل مع البيانات المخزنة في قاعدة بيانات بعدة طرق مختلفة: 


> استخدام ۸00.٤۲‏ /التقنية الرئيسية للوصول للبيانات المضمنة في إطار عمل الدوت نت)/مس مص ه۴۲ ..٤۲‏ للتفاعل مع محتوى قاعدة 
البيانات المخزنة.وهذه هي الطريقة المستخدمة على طول مع برنامج المكتبة للتفاعل مع قاعدة بياناته. وتم شرح آدو دوت نت في الفصل 
العاشرءمع أمثلة عن طريقة استخدامه»وسأقدم أيضا في ذلك الفصل كود خاص من مشروع المكتبة. 

۷ استخدام میزات "تحزيم البيانٽتng data bindi‏ "المتاحة في الفيجوال بيسك والفيجوال أستوديو .يسس التحزيم اتصال بين أداة البيانات التي 
على الشاشة أو كائن تمكين البيانات المشابه والمحتوى من قاعدة بيانات ما.الكود المكتوب لك بواسطة ميكروسوفت يأخذ على عاتقه عمل كل 
الاتصالات ات٬فتستطيع‏ حتی سحب و إسقاط هذه الأنواع من التفاعلات .على الرغم من أنتي سأناقش تحزيم البيانات في الفصل العاشر(حيث أن 
التحزيم يعتمد Eذ١٣”ADO.NET‏ (< »فإني أميل لتجنبهء »لأنه يقلل مقدار تحكم المبرمج الذي يستطيع أن يبذله على معالجة بيانات المستخدم.ولن یتم 
استخدام تحزیم البيانات في برنامج المكتبة. 

> استخراج البيانات من قاعدة البيانات ضمن ملف قياسيءواستخدام ميزات معالجة ملف في الفيجوال بيسك لمعالجة البيانات.من الواضح أن هذا 
غير مفيد جدأءولكنني مضطر لاستخدامه»خاصة في الأيام القديمة عندما كانت قواعد البيانات الخاصة لاتستطيع التفاعل بسهولة مع كود 
الفيجوال بيسك. 

> كل مرة تحتاج فيها لبعض البيانات»اخبر المستخدم أنه بطريقة أو بأخرى قد تم فقدهاءوبالتالي يتوجب إعادة إدخالها مباشرة. فإذا كان لديك 
الس ر دة فر اکل رشا س ا کر و ف 


المحتوى التقني الذي يشرح الجداول والحقول في قاعدة بياناتك للتطبيق تمثل معظم الجزء الهام من التوتيق المولد خلال حياة 
التطبيق.في الواقع »الحاجة لتوثيق جيد هو الأساس فيما يخص واحد من معتقداتي البرمجية الجوهرية:توثيق المشروع هو هامءوفي 
بعض الأحيان أكثر أهمية حتى من الكود المصدريع04€ء 501۲٤€‏ . 

إذا كنت تطور تطبيق ما يتمحور حول قاعدة بيانات تخزن محتوى لمستخدمءالتوثيق الكامل والدقيق لكل جدول وحقل مستخدم في 
قاعدة البيانات هو واجب.وآي نقص في هذه المساحة يجب أن لايكون ممكن آو محتمل»وإذا كان فإنه سيقود قضايا تكامل البيانات 
وابعد من التسلسل الزمني للتطور الضروري كما هو مبين في الشكل التالي: 
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هذا تطييقك بدون توثيق لتاعدة الببانات فى البداية هذه تطبيقك 


السبب الذي يجعلني اعتقد أن توثيق قاعدة البيانات اهم من توثيق المستخدم أو المواصفات الوظيفية»هو الأثر الذي سيترکه 
المستند على بيانات المستخدم. فإذا كان لديك قاعدة بيانات موثقةء فتستطيع ان تخمن ماهية المواصفات الوظيفية»وربما تاتي هذه 
التخمينات دقيقة جدآً.فإذا كان ينقصك توثيق المستخدم ° user documenta†|0‏ »بإمكانك دائما کتابته عندما ينتهي البرنامج .ولكن إذا 
كان ينقصك توثيق قاعدة البیانات ° °٥|†en†aصdocu database‏ .فانت داخل عالم مؤذ. 

إذا لم تعمل من قبل على مشاريع قاعدة بيانات ضخمة»من المحتمل أن لا تصدقني»ولكن لو عملت على وراثة نظام قاعدة بيانات 
واسع ومتکامل ويحوي على الكثير من الجداول وقد شارك فيه أكثر من مطور وکل منهم وضع مجال مختلف من البيانات الذي 
سيسمح لكل حقل أن يحتويهاءوأي من الحقول يجب أن تكون مطلوبة أم لا »فهنا سترى التضارب. 

فتتبع 100,000 سطر من الكود المصدري لتحديد ما يعمله كل حقل(متغير) ليست بالتسلية»ءوقد تأخذ هذه العملية عدة شهور 

لإتمامها بدقة.لذلك لا تدع هذا يحصل معك. 


لنبدا بمجموعة المصادر التقنية لمشروع المكتبة وذلك بتصميم وتوتيق جداول قاعدة البيانات لكي يتم استخدامها بواسطة 
التطبيق ونظهر مجموعة المصادر هذه قي ادلی ت تثبيت الكتاب.في الدليل الجزئي للفصل رابع اوتحتوي على | الملفات التالية: 
ل 


صيغة قاعدة بيانات فر 5Q1 Server database script‏ المستخدمة لبناء الجداول والحقول الفعلية في قاعدة البيانات. 


يحتوي هذا المقطع جدولة بالجداول المحتواة في قاعدة بيانات المكتبة. كل جدول يتضمن وصف عام لمساعدتك في فهم هيكل 
قاعدة البيانات .وسوف تصادف جميع الجداول في الفصول اللاحقةءعلى طول مصحوبة بالكود المصدريعل0» 501۲٣١۵‏ .لذلك لا تغفضب 
freak out‏ إذا بدت ر الجداول أو الحقول صعبة الفهم لك الآن. 


على الرغم من أن الزبائن وهم ليسوا بحاجة لتسجيل الدخولہ| وه! للتطبيق لاستخراج البنودمں )همه!| من قاعدة البياناتءفالمدر اءsإoغadministra‏ 

يجب أن يسجلوا الدخول قبل أن يتمكنوا من الوصول إلى الميزات المحسنة للبرنامج.فالجداول الأربع التالية تدير إعتمادات الأمن ءاجtiثcreden security‏ 

لكل مدير .يستخدم التطبيق قاعدة بيانات سكول سرفر أوءاهنا معا Windows-based security‏ إعتمادات التأمين المعتمدة على ويندوز فقط 

للوصول إلى قاعدة البيانات بشكل أولي,راا ]زم ¡»وليس للحد من(تقیدا s۲‏ ما) الميزات. 

النشاط Activity‏ .يعرف هذا الجدول ميزات التطبيق التي یمکن تأمينها باستخدام مجمو عة ة الحقوقءاطوام group‏ .وهذه النشاطات یتم ربطها مع 

مجموعات الأمن(من جدول مص2١مںهإى)‏ لتأسيس الحقوق لمجمو عة خاصةم particular grou‏ . 

Description 
مفتاح رئيسي.وهذا المفتاح آلي التوليدءوالقيمة المزودة تطابق داخليا القيم‎ 
المستخدمة ضمن مشروع المكتبة.وهو مطلوب.‎ 
Descriptive name of this activity. Required. 
اسم وصفي لهذا النشاط.مطلوب‎ 


Text(50) FullName 
حاليا يتم تعريف النشاطات التالية:‎ 


e 1- Manage authors and names ءlaسأJly إدارة المؤلفين‎ 

e 2- Manage author and name types ءlawألا إدارة المؤلف وأنواع‎ 
e 3- Manage copy status codes خuill إدارة أكواد الحالة‎ 

o 4- Manage media types طilwll إدارة اع‎ 

e 5- Manage series Jڻludا إدارة‎ 

e 6- Manage security groups jJ إدارة مجموعات‎ 

e 7- Manage library materials ةبتSnئlا إدارة مواد‎ 

e 8- Manage patrons jئlبزلا إدارة‎ 

e 9- Manage publishers jıرشlill إدارة‎ 

e 10- Manage system values مlظنلا إدارة قيم‎ 
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e 11- Manage administrative users jييرادإلا إدارة المستخدمين‎ 
e 12 - Process and accept fees معالجة وقبول الرسوم‎ 
o 13 - Manage locations gژlمئا إدارة‎ 
e 14 - Check out library items ةبتکمٹlاl تفحص بنود مخرجات‎ 
e 15 - Check in library items ةبتكnll تفحص بنود مدخلات‎ 
e 16 - Access administrative features Jوصولن الميزات الإدارية‎ 
e 17 -Perform daily processing عمل معالجة يوي‎ 
e 18 - Run system reports pمlظنll تشغيل تقارير‎ 
e 19 - Access patrons without patron password jنوبزئا تمكين الزبائن من الوصول دون الحاجة لكلمة مرور‎ 
o 20- Manage barcodes فaرعتll إدارة أکواد‎ 
° 21-Manage holidays Jطعلا إدارة أيام‎ 
e 22 - Manage patron groups jئlبزلا إدارة مجموعا ت‎ 
e 23 - View administrative patron messages ةıرادإلا عرض رسائل الزبائن‎ 

أسماء المجموعات م۳هل١مuدهإ6.‏ كل سجل في هذا الجدول يعرف مجموعة أمن مفر دة فأمناء المكتبة ومهنإجإطiل‏ وائمدراء administrators‏ 
الأخريين كل منهم ينتمي إلى مجموعة أمن مفردة. 

Description Type 
Primary key; automatically assigned. Required. | Long - Auto 
مفتاح رئيسي»يتم اسناده بشکل آلي. وهو مطلوب‎ 


Name of this group. Required. Text(50) FullName 
اسم هذه المجموعة. مطلوب‎ 


نشاط مجمو عة ٤1۷ا‏ ۸6م اه6. هذا الجدول يصل السجلات في جدول النشاط ل1١0‏ 6هإلى السجلات في جدول اسم المجمرعة 6011004106( علاقة 
عدید -الی-عدید many-to- any‏ لتأسیں نشاطات مجموعة أمن التي يمكکن عملها. 
Description Type Field‏ 


Primary key. The associated security group. Foreign reference Long GroupID 
to GroupName.ID. Required. 
مفتاح رئيسي.المصاحب لمجموعة تأمين.مفتاح ثانوي(علاقة ثانوية) لحقل معرف‎ 
م ں٥6 .مطلوب‎ N2 ۳8.۱0 اسم مجمو عة‎ 


Primary key. The activity that members of the associated Long ActivityID 
security group can perform. Foreign reference to Activity.ID. 
Required. 
. مفتاح ثانوي لحقل النشاط ۱0 .†ا۷اء۸.مطلوب‎ 


اسم المستخدم م4۳ ۲هوءل.يحتوي هذا الجدول السجلات الحقيقية لكل أمين مكتبة أو مدير .يتضمن كل سجل كلمة مرور المستخدم ووضع مجموعة 
الامن . 
Description Type‏ 


Primary key; automatically assigned. Required. | Long - Auto 


Name of this user, administrator, or librarian. Required. Text(50) FullName 
. اسم المستخدم»المدير »أو أمين المكتبة. مطلوب‎ 


User ID that gives this user access to the system. It is entered Text(20) LoginlD 
into the Library program’s “login” form, along with the 
password, to gain access to enhanced features. Required. 
معرف المستخدم والذي يسمح للمستخدم من الوصول إلى النظام.ويتم إدخاله في‎ 
برنامج المكتبة "تسجيل الدخول"على طول مع كلمة المرور٬لتستطيع الدخول إلى‎ 
. الميزات المحسنة .مطلوب‎ 


The password for this user, in an encrypted format. Optional. e eT 
المرور الخاصة بهذا المستخدم»بتنسيق مشفر. اختياري‎ eT 

Is this user allowed to access the system? O for False, 1 for True. Boolean کک‎ 
Required. 
هل سيسمح لهذا المستخدم من التمكن الوصول إلى النظام؟0لخطأء1 لصواب.‎ 
. مطلوب‎ 
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Description Type Field 
To which security group does this user belong? Foreign Long GroupID 
reference to GroupName.ID. Required. 


لئ أي مجموعة أمن ينتمي هذا المستخدم؟مفتاح تانوي  .GroupName.|D‏ 
مطلوب . 


توجد العديد من الجداول تعمل بكل بساطة على تزويد قائمة من القيم لجداول أخرى.في تطبيق ماءقائمة الجداول هذه غالبا ما تظهر كخيارات في أداة 
تتوسع للاسفلسەل-مهإك ("صندوق مرکب×مط مطہهع "). 
نوع مؤلف الكود(أو البند) عمل ۲٥ط dA ut‏ هع .في بر نامج المكتبةءالكلمة ٤0۲‏ هي مصطلح عام مستخدم للمؤلفین ١٥٣ا‏ ںجءالرسامينءالمحررين 
editosءو‏ أي مساهم ۲ 0اuطcontriعمشابه‏ أخر لبند ما في فاتورة المكتبةرمم۷”| رهطا . يتيح لك هذا الجدول من تعريف هذه الأدوار(الوظائف 
.(roles‏ 

Description Type Field 


Primary key; automatically assigned. Required. | Long - Auto 


Name of this type of author or contributor. Required. Text(50) FullName 
N E 
وضع نسخ الكود كلها ۷Sمه 64۵€ €6.تتضمن أكواد وضع النسخ أشياء مثل "الدوران أو معادة وااوانعءإع "٠"المصححة لعءأومها ومامط "»وأي‎ 
حالة رئيسية أخری ترغب المكتبة بوضعھا.حالة تم إعادتھا ہز۔-d م )٥مہ أو تم إخراجھا أو إعارتھا tںم-ل )عم یتم معاملتها من خلال ميزات‎ 
.۲6؟0۲6۸٤6‎ |)" أخرى»كما في العلامة التي تشير فيما إذا بند ما هو بند مرجعي‎ 

Description Type Field 


Primary key; automatically assigned. Required. | Long - Auto 


Name of this status UY ER UE Text(50) FullName 
اسم مدخلة الحالة.مطلوب‎ 


موقع الكود(أو البند) 048610٥3٤10۸‏ 6.المواقع الفعلية حيث يتم تخزين بنود المكتبة .وهذا ما يمن من فصل المواقعءعااء مأجإهمهء »أو الغرف 
reas e gİrooms‏ @ضمن الموقع المشترك common location‏ . 


Description Type Field 


Primary key; automatically assigned. Required. | Long -Auto | ID| 
Name of this location. Required. Text(50) FullName 


The date when Daily Processing was last done for this location. LastProcessing 
If NULL, processing has not yet been done. Optional. 
التاريخ»عند عمل أخر معالجة يومية لهذا الموقع.إذا كان بدون قيمةءفإن المعالجة لم‎ 
يتم عملها حتى الآن.اختياري.‎ 
.C50s .نوع الوسائطمثل الكتب و)مممءالمجلاتءهہاووهم ءالفيديو وم هل السيديات‎ 60de Media ype نوع وسائط الكرد‎ 
Description Type Field 
Primary key; automatically assigned. Required. | Long -Auto | ID, 
Name of this media type. Required. 


Number of days for which items in this type can be checked Integer j CheckoutDays 

out, before renewal. Required. 

عدد أيام البنود التي يمكن استخراجها للبنود التي في هذا النوعءقبل أن يتم 

Integer RenewDays 

عدد الأيام التي يجب إضافتها إلى فترة الاستخراج للبنود المعاد تجديدها ضمن هذا 
النوع.مطلوب. 
Maximum number of times the item can be renewed by a Integer | RenewTimes‏ 
patron before it must be returned. Required.‏ 
SS‏ البند فيها من قبل الزبون قبل أن 


تجديدها.مطلوب. 
e Currency DailyFine‏ ا چ Amount charged per day for an overdue item‏ 
Required.‏ 


Number of days to add to the original checkout period for a 
renewal of items within this type. Required. 
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Description 


الكمية المحسوبة على كل يوم تأخيرء لبند من هذا النوع.مطلوب. 
مجموعة زبائن كرد ص ناه 46۴٣١۸6۲‏ ه6.تصنيفات المجموعات والتي يتم وضع الزبائن ضمنها.وهي ليست مجموعات أمنءولكن هي مجموعات 
عامة لأهداف تقریریةsھ0sم reporting pur‏ . وتم إضافة هذا لدعم تصنيف أو تجمیع الزبائن بوحدات ضمن الشركةءأو بالفئة/الرتبة class/grade‏ 
ضمن مجموعة مكتبة المدرسة . 


Description Type 


Primary key; automatically assigned. Required. | Long - Auto 


Name of this patron group. Required. Text(50) FullName 


€0deSe5.بعض‏ البنود تظهر كجزء من سلاسل أكبر ءهاهء ۲هوه| أو تجمع ۸٥أاعهاامء‏ .فيعرف هذا الجدول أسماء السلاسل والتجمع . 
Description Type Field‏ 
Primary key; automatically assigned. Required. | Long - Auto | ____ID|‏ —€—_ 


الجداول في هذا ١‏ لمقطع تدير الفواتير الحقيقيةر "٤٥۲‏ ٥۷ہ¡‏ اactua‏ .حیث أنه يمكن للمكتبة أن تحوز على أكثر من نسخة لبند مفرد»وتدير هذه الجداول 
"البند المعين بالاسم 6١‏ ۳"60ه" "وهي نسخ a‏ مستقلة وبشكل منفصل . 
Namedıtem‏ .بند المكتبةءمثل کتاب ماءسيدي »أو مجلة .ويمثل هذا الجدول بند اراس النسخة الفعلية للبند. 


Déstription Type Field 


__— Primarykey; automatically assigned. Required. | Long -Auto |__| 


This item’s publisher. Foreign reference to Publisher.ID. Long Publisher 
Optional. 


Dewey decimal number. Use “/” for line breaks. Optional. Text(20) 
Library of Congress number. Use “/” for line breaks. Optional. Text(25) 


ISBN, ISSN, or other standardized number of this item. Text(20) ISxN 
Optional. 


Library of Congress control number. Optional. Text(12) LCCN 


Year of original copyright, or of believed original copyright. Integer Copyright 
Optional. 


The series or collection in which this item appears. Foreign Long Series 
reference to CodeSeries.ID. Optional. 


The media classification of this item. Foreign reference to Long MediaType 
CodeMediaType.ID. Required. E 
نسخة مفردة لبند معين باسمه.النسخ المنفصلة لنفس البند ستظهر كسجلات منفصلة في هذا الجدول.‎ em Cy 
Description Type Field 


_— Primary key; automatically assigned. Required. | Long -Auto |___ ID| 
The related named item record. Foreign reference to eT TT 
Numbered position of this item within the set of copies for a Integer | CopyNumber 
named item. Required, and unique among items with the same 
ItemID field value. = 


Is this copy available for checkout or circulation? O for False, 1 Boolean Available 
for True. Required. 
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Description Type Field 


Has this copy been reported missing? O for False, 1 for True. Boolean Missing 
Required. 


Is this a reference copy? O for False, 1 for True. Required. 
Any comments relevant to the condition of this copy. Optional. Text(30) 
Date this copy was acquired by the library. Optional. 


Value of this item, either original or replacement value. Currency Cost 
Optional. 

The general status of this copy. Foreign reference to Long Status 
CodeCopyStatus.ID. Required. 


Bar code found on the copy. At this time, only numeric bar Text(20) Barcode 
GG TG 

The site or room location of this item. Foreign reference to Long Location 
a E 
المنظمة التي تنشر الكتب أو بعض الأنواع الأخرى من الوسائط.‎ ubاishه‎ 

Description Type Field 
_—___ Primary key; automatically assigned. Required. | Long -Auto |___ ID| 


uth‏ الشخص الذي يكتب وماس »يحرر اله »يوضحوهاهء†وں|ا¡ »أو بطريقة أخرى يساهم sعاںطأ٣‏ امم في بند كتاب أو بند وسيط.في جميع 

الحالات»عندما يظهر بند المؤلف )روفي هذا الجدول»فإنه يشير إلى أي شخص يشارك في البند . 
Description Type Field‏ 

____ Primary key; automatically assigned. Required. | Long - Auto |______ ID| 

Name suffix, such as “Jr.” Optional. 


NamedIteص المؤلف»المحرر»و هكذاءبالنسبة لاسم بند معين.و هذا الجدول ينجز علاقة العديد-إلى-العديد ررمة"-ها-ر مج" بين جدول‎ Nem Auth or 
.Author Jgڏجو‎ 
Description Type Field 


Primary key. The associated named item. Foreign reference to Long ltemID 
Namedltem.ID. Required. 

Primary key. The author associated with the named item. Long AuthorlD 
Foreign reference to Author.ID. Required. 

Relative order of this author among the authors for this named Integer Sequence 
item. Authors with smaller numbers appear first. Required. 

The specific type of contribution given by this author for this Long AuthorType 
named item. Foreign reference to CodeAuthorType.ID. 
Required. 


ل۴6 كلمات خاصة يمكن تطبيقها على البنود المعينة بالاسم وص هاا ”٥۵١‏ هم لجعل البحث أكثر سهولة. 
Description Type Field‏ 
Primary key; automatically assigned. Required. | Long - Auto | ID|‏ —€—›_ 


Namedا†eص يصل لاسرم بالبند المحدد بالاسم(بالبند المسمى ٣اا ١ه" ) من خلال علاقة عديد-إلى-عديد بين جدول‎ tem Keyword 
.Keyword وجدول‎ 
Description Type Field 


Primary key. The associated named item. Foreign reference to ltemID 
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Description Type Field 


Name ID. E. ک۱‎ o. 


Foreign reference to Keyword.ID. Réguifêd 
.) عنونة المواضيع sوہالجه؟ اهزطاںS المستخدمة لتصنيف البنود المسماة(المحددة بالاسم‎ Subject 
Description Type Field 


Primary key; automatically assigned. Required. | Long -Auto | ID| 


Name of this subject. Required. Text(150) FullName 


. Subject Jودجو تصل الموضوع مع البند المسمى من خلال علاقة عديد-إلى-عديد بين جدول ءا لم۸2‎ em Subject 
Description Type Field 


Primary key. The associated named item. Foreign reference to Long ltemID 
Namedltem.ID. Required. 

Primary key. The subject to associate with the named item. Long SubjectID 
Foreign reference to Subject.ID. Required. 


الجداول في هذا المقطع تعرف سجلات الزبون الحقيقية وعلاقتها مع نسخ البند) item copies‏ (عندما یتم تفحص مخرجات مثل هذه النسخ بواسطة 
الزبون) . 

P۴atrn.مستخدم‏ محدد للمكتبةءو عادة للزبائن ءھ۴ امتیازات ءھومااvاام‏ فيما يخص lاlمخرجاتٽ) „(checkout‏ 
Description Type Field‏ 


__—_ Primarykey; automatically assigned. Required. | Long - Auto |___ ID) 


Comments that are displayed to administrative users when the Memo j AdminMessage 
e E E 
Bar code found on this patron's library card. At this time, only Text(20) Barcode 
E 


Patron’s state abbreviation. Optional. Text(2) 
Patron’s postal code. Optional. Text(10) 


The group in which this patron appears. Foreign reference to Long PatronGroup 
CodePatronGroup.ID. Optional. 


. المراجعة حاليا بواسطة الزبون»أو نسخ بند تم مراجعتها سابقاً وقد يتم مراجعتها فيما بعد‎ t٠٠ يدير هذا الجدول نسخ البنود وهمم‎ P۲0٣ 
Description Type Field 


Primary key; automatically assigned. Required. | Long -Auto| |D| 


The associated patron. Foreign reference to Patron.ID. Long Patron 
Required. 

The item copy currently or previously checked out by the Long ItemCopy 
patron. Foreign reference to ItemCopy.ID. Required. 

The date when this item copy was initially checked out. Date CheckOut 
Required. 

The number of times this item copy has been renewed. Set to O Integer Renewal 
when the item copy is first checked out. Required. 
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Description Type Field 


Current due date for this item copy. Required. 
The date when this item copy was returned. Optional. Checkin 


Has the item copy been returned? O for False, 1 for True. Boolean Returned 
Required. 


Is the item copy missing and considered lost? O for False, 1 for Boolean Missing 
e 

Total fine accumulated for this item copy. Defaults to 0.00. An Currency Fine 
ms E 
_____ Total amount paid (in fees) for this item copy. Required. | __ Currency |______Paid| 

When an item copy is processed for overdue fines, this field Date j| ProcessDate 
a 

pa٣0۸ .الغراماتءهہذ۴ ءالتسديدات(المدفو عاتوءامم”رهم )ءالطرد واهءوأصءال على سجل نسخة الزبون رمه‎ Patron Payment 
غرامات التأخير 5٥ا؟ مuلك م0۷ غير مسجلة في هذا الجدول»ولكن الغرامات الموضوعة من قبل المدير تبعا للمسؤوليات بالنسبة للبنود‎ .rمعorا‎ 
. المفقودة تم تسجيلاها هنا‎ 

Description Type Field 


Primary key; automatically assigned. Required. JLong-Auto| ID| 
The associated item checked out by the patron. Foreign Long PatronCopYy 
reference to PatronCopy.ID. Required. 


Date and time when this entry was recorded. Required. EntryDate 


The type of payment entry. Required. The possible values are: Text(1) EntryType 
“P” - The patron made a payment. ° 
“F” - A fine (other than a standard overdue fine) was ° 
imposed by an administrator. 
“D” -A portion (or all) of the fine was dismissed. 
“R” - A refund was given to the patron due to overpayment. 


The amount associated with this entry. The value is always Currency Amount 
positive. Required. 


A short comment about this entry. Optional. Text(50) 
The user who added this payment event. Foreign reference to Long UserID 
UserName.ID. Optional. 


يوجد ثلاث مستويات لتعريف أو إنشاء كود تعريف©1)الصفيحة التي عليها تطبع شبكة من العناوين»(2) عنوان مفرد امطها #اوہاء على صفيحة(صفحة 
اهع3()sh)‏ البنود المستقلة التي تظهر على كل عنوان.الجداول الثلاث في هذا المقطع تعرف هذه المستويات الثلاث. 
BarcodeSheet‏ يصف قالب خاص بصفحة مفردة من عناوين كود التعريف . 

Description Type 


Long - Auto 
Text(50) FullName 
Units used in the various measurements found in most fields in Text(1) UnitType 
this record. Required. 
l=Inches ° 
C= Centimeters 

P = Points 

T= Twips 


Number PageWidth 
Number PageHeight 
MarginLeft 


Number MarginRight 
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Description 


Top border, up to the edge of the printable label area. Number MarginTop 
Required. 

Bottom border, up to the edge of the printable label area. Number | MarginBottom 
Required 


Number |__IntraColumn 
IntraRow 
Integer | ColumnsCount 
Integer |__RowsCount 


Barcode abe‏ يصف قالب عنوان مفرد على صفيحة كود تعريف.أي عدد من العناوين يمكن أن تكون على صفيحة مفردة»ولكن كلها لديها نفس 
الشكل_ ممه ۸وءوالهيئة(التنسيقاج ¬0 ). 
Description Type Field‏ 


Primary key; automatically assigned. Required. | Long -Auto | ID, 
Name of this label template. Required. Text(50) FullName 


The sheet template on which this label template appears. Long | BarcodeSheet 
Foreign reference to BarcodeSheet.ID. Required. 


Units used in the various measurements found in most fields in Text(1) UnitType 
this record. Required. 
l=Inches ° 
C = Centimeters 
P = Points ° 
T=Twips ° 


BarcodeL_abelltem‏ یصف بند مفرد عندما يوجد على عنوان كود تعريف.تتضمن البنود النصوص الثابتة والمولدة»الأسطر٬المستطيلات»و‏ أكواد 
التعريف المولدة . 
Description Type Field‏ 


_—_—___ Primary key; automatically assigned. Required. | Long -Auto |___ JID| 
Identifies the order in which items on the label are printed. Integer Priority 
E E 
The label template on which this item appears. Foreign Long | BarcodeLabel 
e 


What type of item does this record represent? Required. Text(1) lItemType 
T = Static text 
B = Barcode 
N = Barcode number 
L = Line 
R = Rectangle 


Left edge of the item relative to the left edge of the label. Number PosLeft 
Measured according to the related BarcodeLabel.UnitType 
field. Required. 

Top edge of the item relative to the top edge of the label. Number PosTop 
Measured according to the related BarcodeLabel.UnitType 
field. Required. 

Width of the item, or of the box in which the item is drawn. For Number PosWidth 
lines, this is the x-coordinate of the end point. Measured 
according to the related BarcodeLabel.UnitType field. Required. 

Height of the item, or of the box in which the item is drawn. For Number PosHeight 
lines, this is the y-coordinate of the end point. Measured 
according to the related BarcodeLabel.UnitType field. Required. 

Rotation angle, in degrees, of the box in which the item is Integer Rotation 
drawn. Zero (0) equals no angle, and increasing angles proceed 
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Description Type 


clockwise. Ranges from O to 359. Only used when ItemType is T, 
B, N, or R. Optional. 

The name of the font used to write the text. Valid only when Text(50) FontName 
ItemType is T or N. Optional. 

The size of the font used to write the text. Valid only when Number FontSize 
ItemType is T, B, or N. Optional. 

The static text to display on the label. Valid only when ItemType Text(100) StaticText 
is T. Optional. 


The style of the font text. May be any combination of the Text(4) FontStyle 
following four codes. 
B=Bold ° 
|= Italic 
U = Underline ° 
K = Strikeout 
Leave this field NULL to use the normal style. Valid only when 
ItemType is T or N. Optional. 


The main color of the text, bar code, or line. When printing a Long Color1 
rectangle, this is the border color. If NULL, black is used. A 
standard Windows 32-bit RGB color value. Optional. 


The fill color when printing a rectangle. If NULL, white is used. A Long Color2 
standard Windows 32-bit RGB color value. Optional. 


The alignment of the text within the bounding box. Valid only Integer Alignment 
when ItemType is T, B, or N. 
1 = Align in top-left corner of box 
2 = Align in top-center area of boOX 
4 = Align in top-right corner of DOX 
16 = Align in middle-left area of box 
32 = Align in middle-center area of box 
64 = Align in middle-right area of box 
256 = Align in bottom-left corner of box 
512 = Align in bottom-center area of box 
1024 = Align in bottom-right corner of box 


The number of digits in which to pad the bar code number. Set Integer PadDigits 
to zero (0) to ignore padding. Ranges from O to 20. If the bar 
code length is less than the specified number of digits, it is 
padded on the left with zeros. Only applies to ItemTypes of B 
andN. 


يوفر جدولين إضافيين دعم للميزات التي لم يتم معالجتها من خلال الجداول الأخرى. 
6112¥ عندما مراجعة بند ما لزبون»ءفإن التاريخ الراجع يجب أن لايتضمن العطل(أو أي يوم تكون فيه المكتبة مغلقة)»حيث أن الزبون من المحتمل 

أن لاتكون لديه طريقة لإعادة الكتاب في مثل هذا اليوم.يحدد(يعرف) هذا الجدول سابقاً ويرجع اlعطJ „recurring holidays‏ 
Description Type Field‏ 

_—__ Primary key; automatically assigned. Required. | Long - Auto |10| 


The type of entry. Required. From the following list. Text(1) EntryType 
A = Annual (as in “every December 25”) ° 
E = Weekly (as in “every Sunday”) ° 
O = One-time (as in “2/16/2004 is President’s Day”) ° 


Entry-type-specific detail. Required. Differs for each entry type. Text(10) EntryDetail 
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Detail Value Entry Type 


Month and Day in “mm/dd” format 
Single digit: 1=Sunday through 7=Saturday 
Date in “yyyy/mm/dd” format 
تطبق علی کل شبکة‎ يتلاوصiscellaneous‎ enterprise-wide sei ہgs يخزن هذا الجدول إعدادات واسعة ونهائية شتى‎ yt emVaاue‎ 
على کل جھاز »ولیس في قاعدۃ‎ Locaا‎ workstation-spe cific se†)|ہوs حاسوب ۸ 0اأهاو)ممw . يتم تخزين الإعدادات الخاصة بشبكة حاسوب محلية‎ 
البيانات.‎ 
Description Type Field 
_—__ Primary key; automatically assigned. Required. | Long - Auto | ___ID| 


يتم تعريف قيم النظام التالية في الوقت الحالي.واسم الكود يظهر في حقل ١2۳٠‏ عںاه۷.والقيمة الموافقة تظهر في حقل وة 2مںام۷. 


هل كود التعريف مخصص في تنسيق "الكود39”"39 م0 هء“أو "كود3من 9”"9 fه‏ 3 ملهء“؟إذا كان كذلك»سيتم وضع نجمة قبل وبعد رقم كود 
التعريف إمطصنم مهم هط قبل أن يتم طباعته على عنوان ما.استخدم القيمة0 لخطاً هءاج ۴وأي قيمة غير الصفر لصواب(-1 مفضلة).ويتم افتراض 
خطأ في حالة فقدان القيمة أو بدون nة .missing or NULL‏ 


2 


المستخدم لطباعة أكواد التعريف. هذا الخط يجب أن يكون مثبت على أي شبكة حاسوب تعرض أو تطبع أكواد التعريف.وليس هناك حاجة لعمل 
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٤ 
1 
ا‎ 


3 
6 


ار هيكلي لقاعدة البيانات قيد الاستخدام حالياً؟يتم وضعه حاليا إلى"1"ءويتم حفظه من أجل التحسينات المستقبلية. 
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قيمة حقل ٣.10‏ 0 ةه امه من أجل الموقع ۸٥اهعم|الذي‏ يتم وضعه كافتراضي . 


عدد الأيام التي يمكن لبند أن يتأخر ضمنها بند ما دون أن تتسبب في غرامة .without incurring a fine‏ 


قيمة البداية التالية لتستخدم عند طباعة أكواد تعريف بندوهلهء هط |6٠"‏ . 


٤ 
ُ 
8 
E 
3 


التالية لتستخدم عند طباعة أكواد التعريف المختلفة(الشتى( .miscellaneous bar codes‏ 


قيمة البداية التالية لتستخدم عند طباعة أكواد تعريف العميل (الزبونsعلهء patron bar‏ (. 


تشير فيما إذا بإمكان الزبائن استخراج بنود دون الحاجة لتسجيل الدخول كمستخدمين إداريين.استخدم القيمة 0(صفر)لتشير إلى عدم وجود امتيازات 
استخراج وقيمة غير الصفر للسماح لزبون من المراجعة(-1 مفضلة]).فإذا ما فقدت هذه القيمة أو كانت فارغةءفلن يتم السماح للزبائن من استخراج بنود 
دون مساعدة المدير. 


تشير إلى العدد الأكبر من النتائج المعادة في أي عملية بحث.فإذا مافقدت هذه القيمة أو كانت غير صحيحةءيتم استخدام الافتراضي 250.والمجال المسموح 
الشامل ع۷اوں‌اعہ| ھو بین 25و5000. 


يعرض النص الذي يجب طباعته عند أعلى بطاقات مخرجات الدفع.كل الأسطر تتوسط البطاقة.بما فيه حرف الشريط العمودي(|) لتقسيم النص في عدة 
أسطر ٠‏ 


يعرض النص الذي سيتم طباعته أسفل بطاقات مخرجات الدفع.كل الأسطر تتوسط البطاقة.بما فيها حرف الشريط العمودي(|) لتقسيم النص في عدة أسطر. 


يشير فيما إذا تم استدعاء أرقام تصنيف كتاب بواسطة رم سه أو مكتبة الكونغرس(في أمريكا) )1٣(‏ sوهاومه‏ ه لاج۲ طزا.استخدم القيمة 
0 صفر)لتشیر ال gl‘Dewey‏ قيمة غير الصفر ل 1-JLC‏ مفضلة).فإذا ما فقدت هذه القيمة أو كانت فارغة فالافتراضي هر رەس 06. 


إضافة قاعدة بيانات إلى سكول سرفر هي عملية سهلة بقدر سهولة توثيقهاءفي الحقيقةءتتطلب كتابة أقل. و عبارات RA۲۴٤ ۲۸6|٤‏ بسيطة جدأءوتبدو 
جميعها متشابهة إلى حدِ بعيد.وسأريك فقط بعضا منها هنا. (يحتوي ملف/وی ٤م|//i0۸5cاوم/٥‏ مsوطواه2‏ على المحتوى الكامل للصیيغ وقد قمت 
بوضعه في برامج الفصل الرابع). 

التعليمات المجدولة هنا هي من أجل إدارة منصة سكول سرفر 2005 llنسرıعExpress SQL Server 2005 Management Studio‏ .بإمكانك إتمام 
كل هذه المهام باستخدام إدارة منصة سكول سرفر ٠2005‏ أو حتى أدوات أسطر الأمر امه 8اا- ۵٣2٣ص‏ هءالموفرة بواسطة سكول سرفر»ءولكن قد 
تتفاوت التفاصيل بالنسبة لكل خطوة.تعمل نفس عبارات ۲۸861۴ ۸۲۴ مع أي أداة تختار ها.إذا لم تكن قد عملت مثل هذا سابقا. اعمل على تيت 
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سكول سرفر 2005 بطبعته السريعةہ Server 2005 Exp٬ess ٤d0‏ اSQ‏ (أو أي إصدار من قاعدة البيانات سيكون بإمكانك استخدامه).إن إدارة 
منصة سكول سرفر 2005 السريعة منتج مفصول عن سكول سرفر نفسهءلذلك يجب أن تعمل على تنبيتها أيضاً. 
معظم الجداول في مشروع المكتبة هي جداول بيانات بسيطة ذات مفتاح رئيسي مفرد.وکودھا بسیط جدآً,فجدول المؤلف ٥۲‏ طا ں۸ هو مثال جيد. 

CREATE TABLE Author 


( 

ID bigint IDENTITY PRIMARY KEY, 
LastName varchar(50) NOT NULL, 
FirstName varchar(30) NULL, 
MiddleName varchar(30) NULL, 
Suffix varchar(10) NULL, 

BirthYear smallint NULL, 
DeathYear smallint NULL, 
Comments varchar(250) NULL 


J 
تظهر كقائمة محددة بفاصلةاءاا ل6" iامل-مصصهء »وجميعها(الحقول) مغلفة في أقواس.وكل حقل‎ RA ٣ ABا٤ الحقول المضمنة في كل عبارة‎ 
والذي يشير فيما إذا سيتم استخدام القيم بدون قيمة ا الل١في ذلك الحقل أم لا‎ ١07 يتضمن إما خيار بدون قيمة اال أو ليس بدون قيمة اال‎ 
" N07 NU بشکل آلي یخصص "لیس بدون قیمةا‎ |1۸8۷ ۸٤۷ خيار المفتاح الرئيسي‎ 
عمBءهupم‎ ۸2۳٥ بعض العبارات تنشئ جداول تربط جدولين آخرين في علاقة عدید-إلی-عدید.وأحد أمثلتھا جدول را۷ مںه6ءالذي یصل جدول‎ 
„Activity Jgڏج‎ 
CREATE TABLE GroupActivity 


( 

GroupID bigint NOT NULL, 
ActivityID bigint NOT NULL, 
PRIMARY KEY (GroupID, ActivityID) 


ا 

لجدول المؤلف ٥١‏ طا مفتاح رئيسي مفردءلذلك خيار المفتاح الرئيسي يمكن أن يتم إلحاقه مباشرة لحقل المعرف «االتابع له. بما أن جدول 
rup A tivity‏ لديه حقلي مفتاح رئيسي(وهو معروف في قاعدة البيانات العلائقية)»خيار المفتاح الرئيسي ۸K٤۲‏ ۷1۸۸۷ |۴۸ يتم تخصيصه كمدخلة 
خاصة به تماماءمع حقول المفاتيح المخصصة ضمن القوسين والمفصولة فيما بlqiı‏ بفlصlة .PRIMARY KEY (GroupID, Activity|ID)‏ 
سابقا في هذا الفصل ءبينت لك كيف تستطيع تأسيس علاقة لحقل في جدول أخر باستخدام قيود مرجعية( علائقيةا REFERENCES cO sra‏ )کجزء من 
عبارة R۲۴ ٣ AB1٤‏ بإمكانك أيضا تأسيسها بعد أن يتم وضع الجداول في مكانها.(كالذي عملته في ملف صيغة سكول).إليك العبارة التي تؤسس 
اتصاJ‏ ڊjı‏ جڏJg .GroupName Jgدج yGroupActivity‏ 

ALTER TABLE GroupActivity 


ADD FOREIGN KEY (GroupID) 
REFERENCES GroupName (ID); 


حيث أنني قمت بكتابة صيغ سكول الكاملة اماعء 5Q1‏ ١۲اه‏ لك»ءفإنني أطلب منك فقط معالجتها مباشرة باستخدام إدارة منصة ميكروسوفت سكول 

سر فر 2005 السريzعExpress Microsoft SQL Server 2005 Management Studio‏ .( إذا كنت ستستخدم الإصدار الكامل من سكول سرفر أو 
بعض الأدوات الإدارية اهما أ١‏ ٣هوهہهم‏ الأخرىءفإن الصيغ الموفرة ستبقى تعمل »على الرغم من أن تعليمات خطوة-بخطوة ستختلف). قبل إضافة 
الجداول وهاطه)ءنحتاج إلى إنشاء قاعدة بيانات مخصصة لمشروع المكتبةامزه۴ ۷ج۲ طأ] .شغل منصة إدارة ميكروسوفت سكول سرفر 2005 السريعة 
(شاهد الشكل التالي) لإضافة قاعدة بيانات جديدة مءوطهاول سهم لمشروع المكتبةءانقر يمين على مجلد "قاعدة البيانات موءوطو)و( " في مستكشف 
الكائن»واختر "قاعدة بيانات جديدة٣‏ ٥ء‏ مasطهامD New‏ " من القائمة المختصرة. على نموذج قاعدة البيانات الجديد الذي يظهر»أدخل rary‏ ibافي‏ 
حقل اسم قاعدة ase Name‏ Databءومن‏ ثم انقر موافق 0)۸. 

قاعدة بيانات المكتبة مجرد غلاف قاعدة بيانات»ءفهي لا تحتوي أي جدول أو أي بیانات حتى الآن. لنستخدم ملف Database Creation Script sq|‏ 
لإنتاج الجداول والبيانات الأولية.في إدارة المنصة السريعة»اختر ملف م|¡۴>> فتح <<Open‏ أمر قائnمة‏ .أذJۉف menu command‏ 6ا¡۴»وأوجد ملف 
Creation Scr sq‏ t4b2seص‏ .(من الممكن أن يطلب منك تسجيل الدخول لسكول سرفر مرةٌ أخرى) يفتح هذا الملف مساحات لمحتوياته في لوحة 
جديدة ضمن إدارة المنصة ullرڍAz .Management Studio Express‏ 
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ا‎ Microsoft SQL Server Management Studio Express 1 | 
File Edit YWiew Tools Window  Lommunity Help 


Û New Query | ğ (BF 2 E FEB AEE F 


Object Explorer TE Sommar | x 
E: E5 ARETE E | 
IPE IMYSYSTEMASQLEXPRESS 

U Databases U 
e MYSERVER\SQLEXPRESS 
E J Server Objects MM YSE RYE RA SQLEXPRESS 3 [terns 
El Û Replication 
A Management 
Mame 
N Databases 
U Security 
CI Server Objects 
A Replication 
I Management 
4 | 111 ۲ 


4 | 1 ۴ 


Ready 


SQL Server 2005 Management Studio Express main form 
كل ما بقي عليك عمله هو معالجة الصيغةاماامء .في منطقة "شريط الأدوات ٣هطامه) "ءتأكد من أن " رهطا "هي قاعدة البيانات المختارة(شاهد الشكل‎ 
not a |0 وہأمو‎ 0٣ التالي).ومن تم انقر على زر تنفيذ ماںءم×عمن شريط الأدوات»أو اضغط مفتاح ۴5.وهي صيغة صغيرة مع القليل من العوامل‎ 
(على الأقل من وجهة نظر سكول سرفر)ءلذلك سيتم الانتهاء منها في عدة ثواني.‎ 
Û New Query | l | lê | Ë 2F $ HE FE E BEF, 
1: 4 a Library + | BF Execute qy 5) ا‎ 
هذا كل شيءءأغلق لوحة الصيغةامهم أماإءء .ومن ثم »ارجع لمستكشف الكائن6۲١هام×ع اءهزط0 ءوانقر يمين على مجلد قاعدة بيانات المكتبة‎ 
واختر تحديث 5۸ه۲ 86 من القائمة .فإذا ما وسعت بعدئذٍ تفرع قاعدة بيانات المكتبة وجداولها المتفرعة»سترى كل الجداول المنشئة بواسطة‎ L//a 
الصيغة (شاهة الشكل التالي).‎ 
. والآن بعد إتمام قاعدة البيانات»حان الوقت لتبدا البرمجة‎ 
E lJ Library 
La Oatabase Diagrams 
A O Tables 
i System Tables 
E dbo. Activity 
Î dbo.ÃAuthar 
El dbo.BarcodeLabel 
El dbo.BarcodelLabellterr 
El dbo.BarcodeSheet 
Î dbo. CodeûuthorType 
El dba. CodeCopy3tatus 


El dbs. CodeLorcation 
Partial list of database tables 


: كاملا‎ Database Creation Scrip sqlفذ‎ Û سأضمن‎ 
----- */ACME Library Project 
* Database creation script. 
* Start-to-Finish Visual Basic 2005 
* Copyright (c) 2006 by Tim Patrick 
۳ 


CREATE TABLE Activity 


) 
ID bigint PRIMARY KEY 


FullName varchar(50) NOT NULL 
GO 


18 


الفصل الرابع:تصميم قاعدة البيانات 76 mhm‏ 


INSERT INTO Activity (ID, FullName) VALUES (1, 'Manage authors and names‘(' 
INSERT INTO Activity (ID, FullName) VALUES (2, 'Manage author and name types‘(' 
INSERT INTO Activity (ID, FullName) VALUES (3, 'Manage copy status codes‘(' 
INSERT INTO Activity (ID, FullName) VALUES (4, 'Manage media types‘(' 

INSERT INTO Activity (ID, FullName) VALUES (5, 'Manage series‘(' 

INSERT INTO Activity (ID, FullName) VALUES (6, 'Manage security groups‘(' 

INSERT INTO Activity (ID, FullName) VALUES (7, 'Manage library materials‘(' 
INSERT INTO Activity (ID, FullName) VALUES (8, 'Manage patrons‘(' 

INSERT INTO Activity (ID, FullName) VALUES (9, 'Manage publishers‘(' 

INSERT INTO Activity (ID, FullName) VALUES (10, 'Manage system values‘(' 

INSERT INTO Activity (ID, FullName) VALUES (11, 'Manage administrative users‘(' 
INSERT INTO Activity (ID, FullName) VALUES (12, 'Process and accept fees‘(' 
INSERT INTO Activity (ID, FullName) VALUES (13, 'Manage locations‘(' 

INSERT INTO Activity (ID, FullName) VALUES (14, 'Check out library items‘(' 
INSERT INTO Activity (ID, FullName) VALUES (15, 'Check in library items‘(' 

INSERT INTO Activity (ID, FullName) VALUES (16, 'Access administrative features‘(' 
INSERT INTO Activity (ID, FullName) VALUES (17, ‘Perform daily processing‘(' 
INSERT INTO Activity (ID, FullName) VALUES (18, 'Run system reports‘(' 

INSERT INTO Activity (ID, FullName) VALUES (19, 'Access patrons without patron password‘(' 
INSERT INTO Activity (ID, FullName) VALUES (20, 'Manage barcodes‘(' 

INSERT INTO Activity (ID, FullName) VALUES (21, 'Manage holidays‘(' 

INSERT INTO Activity (ID, FullName) VALUES (22, 'Manage patron groups‘(' 

INSERT INTO Activity (ID, FullName) VALUES (23, 'View administrative patron messages‘(' 
GO 


CREATE TABLE Author 

) 

ID bigint IDENTITY PRIMARY KEY« 
LastName varchar(50) NOT NULL. 
FirstName varchar(30) NULL. 
MiddleName varchar(30) NULL‘ 
Suffix varchar(10) NULL‘ 
BirthYear smallint NULL 
DeathYear smallint NULL: 
Comments varchar(250) NULL 

( 

GO 


CREATE TABLE BarcodeLabel 

) 
1D bigint IDENTITY PRIMARY KEY« 
FullName varchar(50) NOT NULL. 
BarcodeSheet bigint NOT NULL: 
UnitType varchar(1) NOT NULL 

( 

GO 


CREATE TABLE BarcodeLabelltem 


) 


ID bigint IDENTITY PRIMARY KEY« 
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Priority  smallint NOT NULL‘ 
BarcodeLabel bigint NOT NULL. 
ItemType varchar(1) NOT NULL‘ 
PosLeft decimal(10,4) NOT NULL: 
PosTop decimal(10,4) NOT NULL 
PosWidth decimal(10,4) NOT NULL. 
PosHeight  decimal(10,4) NOT NULL: 
Rotation smallint NULL. 
FontName varchar(50) NULL‘ 
FontSize  decimal(10,4) NULL: 
StaticText varchar(100) NULL‘ 
FontStyle varchar(4) NULL. 
Color1 bigint NULL: 
Color2 bigint NULL‘ 
Alignment  smallint NULL‘ 
PadDigits smallint NULL 

( 

GO 


CREATE TABLE BarcodeSheet 


) 


FullName varchar(50) NOT NULL: 
UnitType varchar(1) NOT NULL. 
PageWidth decimal(10,4) NOT NULL: 
PageHeight decimal(10,4) NOT NULL. 
MarginLeft decimal(10,4) NOT NULL: 
MarginRight decimal(10,4) NOT NULL. 
MarginTop decimal(10,4) NOT NULL: 
MarginBottom decimal(10,4) NOT NULL. 
IntraColumn decimal(10,4) NOT NULL‘ 
IntraRow decimal(10,4) NOT NULL‘ 
ColumnsCount smallint NOT NULL: 
RowsCount  smallint NOT NULL 

( 

GO 


ID bigint IDENTITY PRIMARY KEY«< 


CREATE TABLE CodeAuthorType 

) 
ID bigint IDENTITY PRIMARY KEY« 
FullName varchar(50) NOT NULL 

( 

GO 


CREATE TABLE CodeCopyStatus 


) 
ID bigint IDENTITY PRIMARY KEY«< 


FullName varchar(50) NOT NULL 
( 
GO 


CREATE TABLE CodeLocation 
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ID bigint IDENTITY PRIMARY KEY« 
FullName varchar(50) NOT NULL. 
LastProcessing datetime NULL 

GO 


CREATE TABLE CodeMediaType 

) 
ID bigint IDENTITY PRIMARY KEY« 
FullName varchar(50) NOT NULL. 
CheckoutDays smallint NOT NULL: 
RenewDays  smallint NOT NULL. 
RenewTimes smallint NOT NULL. 
DailyFine money NOT NULL 

( 

GO 


CREATE TABLE CodePatronGroup 

) 
ID bigint IDENTITY PRIMARY KEY« 
FullName varchar(50) NOT NULL 

5 

GO 


CREATE TABLE CodeSeries 

) 
ID bigint IDENTITY PRIMARY KEY« 
FullName varchar(50) NOT NULL 

( 

GO 


CREATE TABLE GroupActivity 

) 
GroupIlD bigint NOT NULL: 
ActivitylD bigint NOT NULL: 
PRIMARY KEY (GroupID, ActivityID( 

) 

GO 


CREATE TABLE GroupName 

) 
ID bigint IDENTITY PRIMARY KEY« 
FullName varchar(50) NOT NULL 

( 

GO 


CREATE TABLE Holiday 

) 
ID bigint IDENTITY PRIMARY KEY« 
FullName varchar(50) NOT NULL. 
EntryType varchar(1) NOT NULL. 
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EntryDetail varchar(10) NOT NULL 


( 
GO 


CREATE TABLE ItemAuthor 

) 
ItemID bigint NOT NULL‘ 
AuthorlD bigint NOT NULL‘ 
Sequence smallint NOT NULL. 
AuthorType bigint NOT NULL: 
PRIMARY KEY (ItemID, AuthorID( 

( 

GO 


CREATE TABLE ItemCopy 


) 
ID bigint IDENTITY PRIMARY KEY< 
ItemID bigint NOT NULL. 
CopyNumber smallint NOT NULL. 
Description varchar(max) NULL. 
Available bit NOT NULL: 
Missing bit NOT NULL. 
Reference bit NOT NULL: 
Condition varchar(30) NULL‘ 
Acquired datetime NULL‘ 
Cost money NULL: 
Status bigint NOT NULL: 
Barcode varchar(20) NULL: 
Location bigint NULL 

( 

GO 


CREATE TABLE ItemKeyword 

) 
ItemID bigint NOT NULL. 
KeywordID bigint NOT NULL. 
PRIMARY KEY (ItemID, KeywordID( 

( 

GO 


CREATE TABLE ItemSubject 

) 
ItemID bigint NOT NULL. 
SubjectlD bigint NOT NULL: 
PRIMARY KEY (ItemID, SubjectlD( 

( 

GO 


CREATE TABLE Keyword 


) 


ID bigint IDENTITY PRIMARY KEY« 
FullName varchar(50) NOT NULL 
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CREATE TABLE Namedltem 

) 

ID bigint IDENTITY PRIMARY KEY< 
Title varchar(150) NOT NULL: 
Subtitle varchar(150) NULL‘ 
Description varchar(max) NULL‘ 
Edition varchar(10) NULL. 
Publisher bigint NULL: 
Dewey varchar(20) NULL‘ 
LC varchar(25) NULL‘ 

ISXN varchar(20) NULL. 
LCCN varchar(12) NULL 
Copyright smallint NULL‘ 
Series bigint NULL‘ 
MediaType bigint NOT NULL. 
OutOfPrint bit NOT NULL 
) 

GO 


CREATE TABLE Patron 

) 

ID bigint IDENTITY PRIMARY KEY« 
LastName varchar(30) NOT NULL. 
FirstName varchar(30) NOT NULL‘ 
LastActivity datetime NULL‘ 
Active bit NOT NULL‘ 
Comments  varchar(max) NULL: 
AdminMessage varchar(max) NULL. 
Barcode varchar(20) NULL‘ 
Password varchar(20) NOT NULL: 
Email varchar(100) NULL‘ 
Phone varchar(20) NULL. 
Address varchar(50) NULL‘ 
City varchar(20) NULL‘ 

State varchar(2) NULL“ 

Postal varchar(10) NULL. 
PatronGroup bigint NULL 

( 

GO 


CREATE TABLE PatronCopYy 

) 
ID bigint IDENTITY PRIMARY KEY« 
Patron bigint NOT NULL‘ 
ItemCopy  bigint NOT NULL‘ 
CheckOut datetime NOT NULL. 
Renewal smallint NOT NULL: 
DueDate datetime NOT NULL: 
Checkin datetime NULL“ 
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Returned bit NOT NULL: 
Missing bit NOT NULL: 
Fine money NOT NULL: 
Paid money NOT NULL: 
ProcessDate datetime NULL 
( 
GO 


CREATE TABLE PatronPayment 

) 
ID bigint IDENTITY PRIMARY KEY« 
PatronCopy bigint NOT NULL. 
EntryDate datetime NOT NULL: 
EntryType varchar(1) NOT NULL. 
Amount money NOT NULL: 
Comment varchar(50) NULL‘ 
UserlD bigint NULL 

) 

GO 


CREATE TABLE Publisher 

) 
ID bigint IDENTITY PRIMARY KEY< 
FullName varchar(100) NOT NULL: 
WebSite varchar(255) NULL 

( 

GO 


CREATE TABLE Subject 

) 
ID bigint IDENTITY PRIMARY KEY« 
FullName varchar(150) NOT NULL 

( 

GO 


CREATE TABLE SystemValue 

) 
ID bigint IDENTITY PRIMARY KEY« 
ValueName varchar(50) NOT NULL: 
ValueData varchar(100) NULL 

( 

GO 


INSERT INTO SystemValue (ValueName, ValueData) VALUES ('BarcodeCode39', '0‘( 

INSERT INTO SystemValue (ValueName, ValueData) VALUES ('BarcodeFont', NULL‘( 

INSERT INTO SystemValue (ValueName, ValueData) VALUES ('"DatabaseVersion', '14( 

INSERT INTO SystemValue (ValueName, ValueData) VALUES ('"DefaultLocation', NULL‘( 
INSERT INTO SystemValue (ValueName, ValueData) VALUES ('FineGrace', '34( 

INSERT INTO SystemValue (ValueName, ValueData) VALUES ('Licensee', NULL‘( 

INSERT INTO SystemValue (ValueName, ValueData) VALUES ('LicenseCode', NULL‘( 

INSERT INTO SystemValue (ValueName, ValueData) VALUES ('NextBarcodeltem', '20000014(' 
INSERT INTO SystemValue (ValueName, ValueData) VALUES ('NextBarcodeMisc', '10000014( 
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INSERT INTO SystemValue (ValueName, ValueData) VALUES ('NextBarcodePatron', '14(' 

INSERT INTO SystemValue (ValueName, ValueData) VALUES ('PatronCheckOut', '-14(' 

INSERT INTO SystemValue (ValueName, ValueData) VALUES ('SearchLimit', '2504(' 

INSERT INTO SystemValue (ValueName, ValueData) VALUES ('TicketHeading', 'Library System‘(' 
INSERT INTO SystemValue (ValueName, ValueData) VALUES ('TicketFooting', 'Thank you‘('. 
INSERT INTO SystemValue (ValueName, ValueData) VALUES ('UseLC', '04(' 

GO 


CREATE TABLE UserName 

) 
ID bigint IDENTITY PRIMARY KEY« 
FullName varchar(50) NOT NULL. 
LoginlD varchar(20) NOT NULL. 
Password varchar(20) NULL: 
Active bit NOT NULL: 
GroupID bigint NOT NULL 

GO 


ALTER TABLE GroupActivity ADD FOREIGN KEY (GroupID) REFERENCES GroupName (ID‘( 
ALTER TABLE GroupActivity ADD FOREIGN KEY (ActivitylID) REFERENCES Activity (ID‘( 

ALTER TABLE UserName ADD FOREIGN KEY (GroupID) REFERENCES GroupName (ID‘( 
ALTER TABLE Namedltem ADD FOREIGN KEY (Publisher) REFERENCES Publisher (ID‘( 
ALTER TABLE Namedltem ADD FOREIGN KEY (Series) REFERENCES CodeSeries (ID‘( 
ALTER TABLE Namedltem ADD FOREIGN KEY (MediaType) REFERENCES CodeMediaType (ID‘( 
ALTER TABLE ItemCopy ADD FOREIGN KEY (ItemID) REFERENCES Namedltem (ID‘( 
ALTER TABLE ItemCopy ADD FOREIGN KEY (Status) REFERENCES CodeCopyStatus (ID‘( 
ALTER TABLE ItemCopy ADD FOREIGN KEY (Location) REFERENCES CodeLocation (1D‘( 
ALTER TABLE ItemAuthor ADD FOREIGN KEY (IltemID) REFERENCES Namedltem (ID‘( 
ALTER TABLE ItemAuthor ADD FOREIGN KEY (AuthorlD) REFERENCES Author (ID‘( 

ALTER TABLE ItemAuthor ADD FOREIGN KEY (AuthorType) REFERENCES CodeAuthorType (ID‘( 
ALTER TABLE lItemKeyword ADD FOREIGN KEY (lItemID) REFERENCES Namedltem (ID‘( 
ALTER TABLE ItemKeyword ADD FOREIGN KEY (KeywordID) REFERENCES Keyword (ID‘( 
ALTER TABLE ItemSubject ADD FOREIGN KEY (IltemID) REFERENCES Namedltem (ID‘( 
ALTER TABLE ItemSubject ADD FOREIGN KEY (SubjectlD) REFERENCES Subject (ID‘( 

ALTER TABLE Patron ADD FOREIGN KEY (PatronGroup) REFERENCES CodePatronGroup (ID‘( 
ALTER TABLE PatronCopy ADD FOREIGN KEY (Patron) REFERENCES Patron (1D‘( 

ALTER TABLE PatronCopy ADD FOREIGN KEY (ItemCopy) REFERENCES ItemCopy (ID‘( 
ALTER TABLE PatronPayment ADD FOREIGN KEY (PatronCopy) REFERENCES PatronCopy (ID‘( 
ALTER TABLE PatronPayment ADD FOREIGN KEY (UserID) REFERENCES UserName (ID‘( 
ALTER TABLE BarcodeLabel ADD FOREIGN KEY (BarcodeSheet) REFERENCES BarcodeSheet (ID‘( 
ALTER TABLE BarcodeLabelltem ADD FOREIGN KEY (BarcodeLabel) REFERENCES BarcodeLabel (1D‘( 
GO 


----- */Create the basic security account/” . 
INSERT INTO GroupName (FullName( 
VALUES ('Administrators‘(' 


INSERT INTO GroupActivity (GroupID, ActivityID( 
SELECT 1, ID FROM Activity 
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INSERT INTO UserName (FullName, LoginlD, Active, GroupID( 


VALUES ('Administrator', 'admin', 1, 1%( 
GO 
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الnجilaa Assembly‏ 
مجمعات الدوت نت هي مجرد ملفات ع×عو اا0(مكتبة الربط الديناميكي راهطا )ذا عاص همرك).بدون الحاجة لتفعيلها من قبلك»فهي تحتل مساحة تجميعية من 
القرص.وبما أنها لا تعمل أي شيء أخرءلذلك لنتفحص ماهي هذه المجمعات وماذا تحتوي . 


المجمع هو "وحدة نشر†/مصره‌اممل ٤ه ut‏ "والتي وفي معظم الحالات هي ملف فقط .فالمجمع مستو د ع0۲۷أوم مهم معد للترجمة من قبل كود تطبيق دوت 
نت .»فاي كود تكتبه سيتم تخزينه في النهاية في ملف ع×E(إذا‏ کان تطبيق) أو ملف اا0(من أجل مكتبات الكود اطا لمعأو امتدادات ت تطبیق). کل شيءِ 
تحتاج معرفته حول الدوت نت لتحميل وتشغيل تطبيقك يتم تخزينه في مجمع راا" 50ءه. 
المجمعات هي إما خاصة riva‏ مأو leمpublic EE.‏ الخاصة ءءز/(”رعءءه ۶/16 للاستخدام في تطبيق مفرد فقط.فإذا لم يكن هناك أي 
ئاا0»فمجمع ٤×ع‏ هو التطبيق .تظهر المجمعات الخاصة في دليل خاص بهاء دليل التتصيب ر/هاء مأل 0۸ن٤14//4و”/‏ للتطبيق أو المكتبة. 
بإمكانك تشغيل مجمعين خاصين مختلفين في نفس الوقتءولن يتعارض۲٥٣هط‏ كل منهما مع الآخر.وهذا صحیح حتی ولو کان كل مجمع يستخدم نفس تركيب فضاء 
الأسماء وأسماء الفئة لعناصره المكودة(المشفرة).فإذا مجمعا تطبيق »كل منهما ينفذ فئة مسماة s1ءھ!٣. i0۸1‏ icaاeNindowsApplفلن‏ یتداخل fere‏ عtہiکل‏ منھما مع 
الآخر عند التشغيل»ءفهما خاصانهاه۷أإم »وخاص هأه۷أ۲م يعني خاص ۲۷2م . 

iesاassemb‏ icاubللاستخدام‏ المتشارك بين تطبيقات الدوت نت المتعددةوہما†هء‌iاممa .N.E۲‏ مامtiاuص‏ .تختلف المجمعات العامة 
iesاassemb‏ icاPub‏ عن المجمعات الخاصة هاا(" هءءه ماج۷آ۲م في طريقتين رئيسيتين: 

ه المجمعات العامة دائما لديها اسم قر يع ه۸ و ٠ى‏ ءتوقيع رقمي مشفر ءإںاه٠واء‏ اهااواك ١هامرإعمه‏ متعلق بمجمع ما لضمان أنه يأتي من البائع 
المسمى 0۲ل ع۷ dعمص‏ هم أو المصدر هعںهمء . (يمكن للمجمعات الخاصة أن تتضمن اسم قوي»ولكن هذا ليس بالمستوجب).يتم بناء الاسم القوي من اسم 
المجمع»رقم النسخة(الإصدار)»› > معلومات تقافيةءالكلمة أو"المفتاح public keyple‏ "»والتوقيع الرقمي r‏ ںاھ واو digital‏ المولد من ملف مجمع يحوي 
الكشف ءاره ".يتضمن إطار عمل الدوت نت أدوات تولید اسم قوي exe)‏ ی )والذي يساعد في هذه المعالجة»وتتضمن فيجوال أستوديو خیارات تتیح 
لك من إضافة توقيع رقمي خلال عملية التر جمةووععه۲م compilation‏ . (وهي ليست تبويب معين في صفحات خاصيات المشروع ءا زام 
sهopertiام).الاسم‏ القوي لمجمع ما يجب أن(ومن الأفضل أن يكون) مفرد ومميز»إذا ما تشارك مجمعان اسم قوي مشترك»فإنهما نسخ لنفس المجمع. 

ه يتم تخزين المجمعات العامة في الذاكرة الانتقالية للمجمع الشامل ٥a٥ )G۸٥(‏ راط"عءءه اهطهاىB.‏ على الرغم من أنك تستطيع وضع نسخة من 
مكوناتك المتشاركة في دليل تنصيب تطبيقك رماع هال ااهأو١|‏ s٣هناهءiاممج‏ »فستكون صحيحة التشارك فقط عندما تصل لدليل ٥6۸.يقيم 6۸٥‏ في 
دلیل مسمی مجمع ,/ا"/عئی‌ضمن دلیل ویندوز للکمبیوتر Windows dir cory‏ uter'sمصد‌ه‏ .(علی نظامي»فهو فير/ا”/seءئھاsسw/^d0w|:›‏ 
)حالما يكون لمجمع الدوت نت اسم قوي مطبق»بإمكانك إضافته إلى ٥6۸بواسطة‏ إما سحب الملف لضمن دليل المجمع ر/طا”رعءءو أو استخدام أداة 
الذاكرة الانتقالية للمجمع الشامل(ع×م./1ا٥2و) Cache ۲0١‏ yاembءAss‏ اطا .ولا تقلق بالنسبة لملفك الوحيد إذا لم يتجاوب مع الملفات المثبتة 
fies.‏ edااnsta¡.في‏ النسخة المثبتة حديتا للدوت نت٣..‏ ءيمكن أن تجد تقريبا 400ملف موجودة مسبقاً في دليل 6۸٥‏ »من ضمنها كل 011 الخاصة 
بمكتبة فئة إطار العمل(ء۴°1) Framework Class Libraries‏ .تتیح لك الدوت نت ..E۲‏ من تثبیت عدۃ إصدارات ءہمایم۷ ھاماااںuم‏ من مجمع 
ما راط" هءءهعلى النظام واستخدامهم في نفس الوقت(مثل هذه المعالجة تدعى التوافقية eR E‏ ).و هذه تقدم )E×E(و‏ lلمكتبlٽ)LL)( libraries‏ 
للتطبيق »ومن أجل المجمعات الخاصة والمجمعات المتشاركة في ۸٥‏ .افتح مجلد مجمع راؤ”/عووه ء٥0‏ 6۸»ءوضع مستكشف المجلدات ۲٥rاoاExp‏ 
هلام إلى "عرض التفاصيلءانهه0 "»ومن ثم رتب ۲مءبواسطة اسم المجمع 4"6 راا"۳هءء۸ .إذا حركة شريط التمرير للأسفل»سترى نفس 
الملفات المبينة عدة مرات.يبين الشكل التالي جزء من الذاكرة الانتقاليةم عه .يتم جدولة نسختان “Microsoft. VisualStudio.Windows.F0rms”jn‏ 
(من ملفا Micros Visua/Studio. Windows. Fors.‏ )واحدة مع رقم النسخة 2.0وأخرى مع رقم النسخة .9.0. على الرغم من أنه يوجد عادة 
علاقة واحد -إلی-واحد بين الملفات والمجمعاتءفیمکن أن توجد حالات عندما یتم ترکیب مجمع من عدۃ ملفاتیم|ا؟ ماماtاںص‏ .على سبیل المتالءيمکن 
لتطبيق أن يتضمن ملف صور(رسوميياام هن )خارجي في عرض المجمع سه۷ راط هءءه الخاص به.يراقب الدوت نت هذه الملفات بحرص 
شديد.فإذا تم تعديل ١مم"‏ أي من هذه الملفات»حذفت ١‏ همام »أو من ناحية أخرى تشوهت له" اهم" ءفسوف تعلم بها.فيما يخص الشرح هناءفإن باقي 
الفصل سيأخذ بعين الاعتبار المجمعات ذات الملف المفردومiاطعءءه‏ ءeااfi-ماوsin‏ . 
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ملف لحرير عرض المغضلة أدوات العليمات 


@ اد ن î‏ کر بحث | مجلدات ا Folder Sync EH P4‏ 


CW INDOWSazsembly |) jlیٹ‎ 

NetZero E-mail on the web My NetZero تخصيص الارئباطاث‎ 3 windows Media 3 irda 3 مجائي‎ Hداداا‎ 3 Links 
|...Procezs | Public Key Token |... Yersion ___ Assembly Name 
T1bF3BBad 3435 .**,* ..MicrosollYisualStudi 
BO31 A50a3a **,* .MicrosoflYisualStudi 
BOSH A50232 +, MicrosoflYisualStudi 
BO31 A50232 „*,*,* ..MicrosollYisualStudi 
BO31 A50a3a FEY ....Microsolt.YisualStudi 
BO31 A50232 *,*,* ..MicrosoflkYisualStudi 
BO31 A50a3a .**,* ..MicrosollYisualStudi 
BO31 A50232 *,*,* ..MicrosoflYisualStudi 

d 

d 

d 

d 


BO37 50a3a FEY Microsoft. YisualStudi 
bO S0a3a **,* ..MicrosoflYisualStudi 
BO37 50a3a „*,*,* ..MicrosoflYisualStudi 
bO 50a3a .*,*,* ..MicrosollYisualStudi 
bO3HFId5Ua3a + + *_...PMicrosoftyisualStudi 


The GAC has this duplication under control 
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ملف ع ×ع أو اا0 للمجمع هو الملف ع۴ "تنفيذي قابل للنقل 0نا م×ع ماطهامم " القياسي » نفس تنسيق الملف المستخدم من أجل الملفات القابلة للتنفيذ في 
غير الدوت نت ومكتبات الكود(متل الكثير من آي ملف ویندوز ٤×€عاو‏ ااD).ما‏ يجعل ملفات الدوت نت التنفيذية والقابلة للنقلوم|ا؟ ..٤۲ P۴‏ مختلفة هي کل 
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الأجزاء المحشوة الإضافية ن )»م الموجودة داخله.بشكل عام الكلمة مجمع تشير إلى جمع الأجزاء المتنوعة مع بعضها ضمن وحدة مفردة.في مجمع ما للدوت 
نت» هذه "الأجزاء المتنو عة"مصممة بشكل خاص للاستخدام مع الدوت نت .يحتوي ملف دوت نت القابل للنقل ع۴ ..٤۲‏ على ثلاث أجزاء رئيسية: 

A PE header "Jذنلل معنون "تنفيذي قابل‎ 

مطلوب لكل ملفات »هذا المقطع يحدد(يعرف) المواقع بالنسبة للمقاطع الأخرى من الملف. 

The MSIL code section ةطيسوll مقطع كود لغة ميكروسوفت‎ 

يتم تخزين الكود الفعلي المصاحب المجمع ككود لغة ميكروسوفت الوسيطة شبه llئnترجم gul.semicompiled Microsoft Intermediate Language (MSIL)‏ ء 
الحظ٬شريحة‏ chipانتل‏ ilntelو‏ ۸0 في كمبيوترك بکل وضوح بلهاء كثيراً لمعالجة كود لغة ميكروسوفت الوسيطة بشكل مباشر٬لذلك‏ يتضمن إطار الدوت نت 
مترجم فوري e۲|ا¡م‏ "0۳ء (۲|ل) "٩‏ -/-اءر/بإمكانه تحويل لغة ميكروسوفت الوسيطة |15 إلى كود 86×الأصلي ذور at a moment's notice‏ . 

The Metadata section ٽlنlيبll مقطع توصيف‎ 

کل التفاصيل الإضافية التي يحتاجها الدوت نت للبحث ضمنه rummage through‏ وذلك لمعرفة ما يخص مجمعك تظهر في هذا المقطع الاساسي.بعض من هذه 
البنود»عندما تأخذ مع بعضها ءتگون كشف المجمع اوع؟ زمه ء”رااعءوه(نوع مستند يشر ح المجمع للعالم بالكامل).في القائمة التالية من عناصر توصيف البيانات 
metadata elements‏ أشرت إلى البنود التي تظهر في الكشف اوع۴¡١ه":‏ 


1 
5 
% 


(جزء من الكشف )يتم تحديد هذا الجزء على تبويب التطبيق ۸ ٠0ااهiاممه‏ لخاصيات المشرو ع .project’s properties‏ 


(جزء من الكشف)وهو عدد من أربع أجزاء للنسخةءكما في ريما تالت في يوم من الأيام عن كيقية وشح هذا العدذ في مشراوعك الخاصن,سيئم الرد على 
صبرك في هذا الفصل وفي مقطع "المشروع"»عندما سوف أوضح ليس فقط طريقة ولكن اثذ ثنتين عن كيفية وضع رقم نسخة المجمع. 


(جزء من الكشفاءم؟ا ج" )يتضمن المفتاح العام dأiشر .publisher’'s public key‏ 


(جزء من الكشف).سترى مجمعات ملف مفرد فقط اسم ملف EXE‏ أو اا0ءولكن بعض المجمعات يمكن أن تتضمن عدة ملفات في هذا المقطع. كل الملفات في 
مجمع يجب أن تظهر ضمن نفس الدليلرءمء مال »أو في دليل تابع ماع اك۲هطنولملف المجمع الذي يحوي الكشف وع¡ 2". 


(جزء من الكشف)بعض المجمعات "تصدر "بعض من أنواعها لأن تستخدم خارج التطبيق.فتفاصيل هذه الأنواع تظهر في هذا المقطع. 


(جزء من الكشف»ولكن في المجمعات المتعددة الملفات»كل ملف سيحتوي قائمة خاصة به من المراجع)تتضمن وصف البيانات netadataجدولة‏ لجميع المجمعات 
llخlرجة external assemblies‏ المرجعة(المشار اليها )بواسطة تطبيقك»فيما إذا كانت خاصة gİprivate‏ تظهر في 6A٥‏ .تشير هذه القائمة إلى أي إصدار خاص 
specific version‏ تقافةعturاcu‏ »والمنصة المستهدفة اموه" ۲٥؟اهام‏ للمجمع الخارجي الذي يتوقعه مجمعك . 


(ليست جزء من المانفست ءه؟ام جم أو الكشف)كل الأنواع المعمولة(المبرمجة)في مجمعك يتم وصفها بالكامل ضمن وصف البيانات(الميتاداتاعج ل جام ) 
.أيضاءيظهر هنا أي وصف بيانات إضافي اة لهام" اعهااك هه تم إضافته لأنواعك من خلال ميزة مواصفة الفيجواJ‏ بسك Visual Basic’s attribute‏ 
ماatuه]f.‏ في المجمعات المتعددة الملفات»تظهر العناصر الخاصة بالمنانفست ءأ” ع "هاه ءاfاممء-اsمfامaص‏ فقط في الملف الرئيسي”٠أه"“‏ للمجمع . 
المانفست (الكشف)هو مجموعة جزئية من الميتاداتا ضمن مجمعك.وإني أكره أن آقول أنها الجزء الأكثر أهمية للميتاداتاءولكن هي كذلك.فالمنانفست هو تعبير عام 
ك»والطريقة الوحيدة التي يعلم فيها الدوت نت فيما إذا كان مجمعك شر عي(صحيح.اأوها ). 
حتی i‏ ظهور الدوت نتءكانت الملفات القابلة للتنفيذ ءاطعا ںءم×هوالمكتبية 5اا تحتوي بعض "المیتاداتاءمتل رقم النسخة(الإصدار)للملف للملف »ولكن لم تکن 
هذه البيانات تستخدم لإدارة الوصول بين المكونات البرمجية»ولا حتى كانت منظمة في بطريقة عامة وقابلة للتو سیع(التمدید م‌ااوہ 6ا x×م‏ ( .تشمل الميتاداتا في الدوت 
نت كل هذه المواصفات.ان وجود كل من لغة ميكروسوفت الوسيطة |18 والميتاداتا 4ص في کل مجمع تجعل هذا الملفات قابلة للقراءة والفهم بشكل 
جد .بالأدوات المناسبة With the right tools‏ »حتی ولو کنت أبدو أني أفهمها »وحتی لو استطعت»فأي شخص بإمكانه»و هذا ما يقود لمشكلة كبيرة. إن الشركات 
تستثمر الكثير من الوقت والنقود على الجهود التي تعمل على تطوير برمجياتهاءولا تريد من أي مبرمج متطفل أن يعكس هندسة كودها ويحصل على جميع أسراره 
وخوارزمياته السرية.ولمنع القراءة العرضية وال۲6 casual‏ لأي من تطبيق الدوت نت. عملت ميكروسوفت وجهات أخرى هام ۸۲١‏ على تضمين 
المبهم(المشوش 5ع )»وهي البرامج البرمجية التي تشفر(تدمج ) محتوى أي مجمع بشكل كافي مما يجعل من الصعوبة بمكان لأي شخص من أن 
يفهمه»ولكن ليس بالنسبة لإطار عمل الدوت نت»سأتكلم أكثر حول التشویش ١٥ھ‏ ءںطه فيما بعد . 


إنه يبدو شيء سيء أن يتمكن الناس من الوصول لمحتوى مجمع ماءوإنه لعظيم أن يتمكن الكود في مجمع من الوصول لنفسه.تتضمن الدوت نت مواصفة تدعى 
اع تتيح لك تفحص محتويات مجمع ما.بشكل عام تستخدم هذه المواصفة للوصول إلى الميتاداتا واج لهه في مجمعك الخاصءولكنها تعمل أيضا مع أي 
متاح. تظهر معظم الميزات المتعلقة بالانعكاس في فۈضlءs .System.Reflection namespace slaw)!‏ 

من خلال الانعكاس بإمكانك استخراج تقريبا كل شيء مخزن في الميتاداتا وال هاه لمجمع ماءومن ضمنها تفاصيل على كل الأنواع»أعضاءهاءوحتى الوسيطات 
المضمنة مع أعضاء الدوال .وهذا ما يجعل التشويش ١0اه‏ وں؟طم‌هام جداً بالنسبة للبائعينء0ل مه۷ »بين لغة ميكروسوفت الوسيطة المترجمة |18 ١ء‏ اأمc0‏ 
والميتاداتاهاو لوهم ءبإمكانك افتراضيا إعادة توليد الكود المصدري بالكامل لتطبيق ما فقط من ملفه القابل للتنفيذ.ولن يكون بتلك الصعوبة بالنسبة لشخص ما 
متمرس في استعادة الكثير منه ضمن الفيجوال بيسك أو#° . 


ا 


تطبيقات الدوت نت(ملفات تنفيذية €E×X)هي‏ حالة(نسخةعع ^ insta‏ )من مجمع»ولکن يمكن لتطبيق مفرد أن يحوي على عدة مجمعات»في الحقيقة»ءإنه غالبا ما يكون 
كذلك. قمت بكاتبة برنامج صغير يستخدم الانعكاس لجدولة جميع المجمعات راع۷ااعج كهااطص"هءءه ااج وا التي تم استخدامها فعليا رام۷زامج بواسطة البرنامج 
نفسه» و أعطيته الاسم الافتر اضي ١1‏ 0/اجء//مم ۷۵0۷54 .وعندما شغلت البرنامج على نفسه»ءولد القائمة التالية: 


mscorlib 
Microsoft.VisualStudio.Hosting Process. Utilities 
System.Windows.Forms 


المجمعات 


N 
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System 

System.Drawing 
Microsoft.VisualStudio.HostingProcess.Utilities. Sync 
Microsoft.VisualStudio.Debugger.Runtime 

vshost 

System.Data 

System.Deployment 

System.Xml 

System.Core 

System.Xm!.Linq 

System.Data.DataSetExtensions 
Microsoft.VisualBasic 

WindowsApplication 1 

System.Runtime.Remoting 


كما ترى 17مجمع من ضمنها 1 ”رم/اaء//ممs4س0هn Vi‏ البرنامج الرئيسي "9۲١۲م‏ "اه" .معظم المجمعات واا مزودة من قبل إطار اlعJa-framework‏ 
iedاsupp.من‏ أجل ميکر وسوفت.فيجو ال بيسڭ ء2 ۷isu2a|8.¦؟0s0ءMi‏ المجمع هو //d.ء/۷isua/82s Microso#٤‏ »ومن أجل النظام ۳هاءر6ءالمجمع هو 
.System.dll‏ 

كل المجمعات (ما عدا مجمع البرنامج الرئيسي)هي متشاركة المكتبات ءهاإج۲طذامن ٥6۸.يمكن‏ للتطبيق أيضاً من دعم مجمعات خاصة private assemblies‏ 
محملة من ملفات 1ا0 محلية . 

یحمّل إطار عمل الدوت نت)۲ه س هه۴۲ ..٤۲‏ هذه المجمعات لي بشكل آلي عندما يشتغل ۸1 0ناهء//ممW54‏ ۷۵0 ءإنه يستكشف أي منها فيما إذا كان هناك 
حاجة إليه لكي يتم تحميله وذلك بالنظر في المانفست ل ٠1‏ 0اهء//امم ۷/۵0۷54 .عندما حمل إطار العمل كل مجمع»ءفإنه يتفحص ليرى فيما إذا كانت هذه المجمعات 
بدورها تحتاج لمجمعات إضافية ليتم تحميلهاءو هكذا.تطبيق بسيط وحيد أصبح أرض تفريغ للمجمعات من كافة أنحاء ٥6۸.ولكن‏ هذا جيدءبما أن هدف الدوت نت هو 


إدارة هذه المجمعات جميعها. 


إن إطار العمل مع الآلاف من فئاته»يحتوي الكثير من المنطق المشحون(المحزمءاوه| packaged‏ )والذي بامکاني استخدامه في برنامجي الخاص.ولكني لا املك 
تذكر المجمعات العديدة وفئاتهم الكثيرة.وقد يأخذ الكثير من الوقت لتطوف ضمن توثيق مكتبة فئات إطار العمل ioاھ†"eصuعمل‏ ا٥۴‏ .مع الكثير من الفئات 
المتاحةءفإني في بعض الأحيان أرتعد ۲٥ل‏ ل مءعندما أفكر بالجهد الذي سأبذله لإيجاد الفئة الصحيحة فقط أو الميزة التي أحتاجها لإتمام بعض مهام 


التطوير(البرمجة) . 


لحسن الحظءلست الوحيد الذي يفكر بهذه الطريقةءفميكروسوفت تتفق معي.تاريخيا »كان مبرمجي فيجوال بيسك محميين ١٠٠٠ام‏ ومن التعقيدات في تطوير تطبيق 
ويندوز.وليس هذا ما يحتاجون أن يكونوا عليه»فنحن جميعا نعرف أن مطوري الفيجوال بيسك بشكل عام مفضلين على الباقي.ولكن "كان شعار الفيجوال 
البيسك"التحاور على:جعل تطویر ویندوز اسر ع و أسھلرsھع‏ 2^0 Make Windows Development Fast‏ .واستدعاء بعض الطرق المقتصرة ٣|٥‏ ع†s0م‏ 
والراسخة ضمن أجزاء sامسb0نظام‏ فضاء الأسماء aceمesصamم‏ mمtءرك‏ لتحصل على القسم الرئيسي من البيانات وهو ليس بالسهل ولا حتى بالسريع. 
ولاستعادة بعض البساطة والسرور التي كانت متاحة سابقا في الفيجوال بيسك»عملت ميكروسوفت على تقديم استدعاء فضاء الأسماء ر0 في إصدار 2005من 

اللغة .يضم استدعاء فضاء الأسماء ر0 الكثير من الميزات المفيدة من كامل ٥|‏ ۴»ءويعمل على تنظيمها في طبقات هرمية ء٣‏ ههام أكثر صغراً من أجل البساطة 
والسهولة في الوصول.ولقد قمت بذكر باختصار رفي الفصل الأولءولكن حالي من الجيد أخذ نظرة أقرب لما يفعله. 

يبدو pretend namespace‏ مستدعي فضاء الأسماء ر مشابه كتير لي فضlء‏ lnİء‏ Îخر«nڌJ .System.Windows.Forms g«System.Reflection «System‏ 
ولكنه في الحقيقة ليس فضاء أسماء-فهو مستدعي ل١‏ هاع۲م. 

لسبب ماءلاتستطيع استخدام الكلمة المحجوزة امم الإنشاء اختصار للتفرعات(التشعبات )ضمن هيكله الهرمي.على الرغم من أن بعض المقاطع من هرمية 
التسلسل هي ديناميكية ءفهي تتغير كما يتغير مشروعك»يجدول الجدول التالي العقد ههه الرئيسية للتسلسل الهرمي . 


My.Application 
My.Application.Info 
My.Application.Log 

My.Computer 
My.Computer.Audio 
My.Computer.Clipboard 
My.Computer.Clock 
My.Computer.FileSystem 
My.Computer.FileSystem. 
SpecialDirectories 
My.Computer.Info 
My.Computer.Keyboard 
My.Computer.Mouse 
My.Computer.Network 
My.Computer.Ports 
My.Computer.Registry 
My.Forms 
My.Log 
My.Request 


My.Resources 


يوفر معلومات حول التطبيق الحالي»ومن ضمنها إعدادات الخيارات الإقليمية وطرق النشر . 

يعطي معلومات آكثر حول التطبيق ومجمعاته»ومن ضمنها الاسم مص هم والنسخة 0أvers.‏ 

يسمح لك توليد متتبع ومخرجات تسجيل دخول لأغراض تسجيل الدخول المسجلةء»ويستخدم فقط مع تطبيقات العميل 
يوفر إمكانية الوصول إلى المصادر العامة المتواجدة على الكمبيوتر المحلي. 

يشغل آصوات النظام وأصوات آخرى محددة من خلال سماعات الكمبيوتر . 

يستخلص البيانات من حافظة النظام»ويتيح لك إضافة بيانات خاصة بك للحافظة في تنوع محدد مسبقا وتنسيقات خاصة. 
يحصل على تاريخ النظام الحالي والوقت المعروض بطرق متنوعة. 

يوفر ادوات لتفحص ومعالجة الملفات والاقراص فل أنظمة الملفات filesystems‏ المحلية او الشبكية 

يشير إلى مجلدات ويندوز الخاصة متل المستنداتوا م (0cu‏ «سطح المكتبمه] )وم( »والمجلدات المؤقتة م٥7‏ . 


رر رمات ن ر ی الت رار ا ات ا 

ا ا ای ا ا ا 

ال ين الاك رة ار اي ك 

يبلغ عن الشبكة المتاحةءويوفر ميزات للتفاعل مع تلك الشبكة. 

يتيح لك التفاعل مع مداخل(منافذ أو شقوق)النظام التسلسلية وأرمم امأممء ms‏ مأكرs.‏ 

يقرا ويكتب المفاتيح ورم )والقيم وع اهجرفي المسجل رءأءاوه. 

يجلب تجمع ديناميكي لكل النماذج المعرفة في التطبيق.وهذه العقدة متاحة فقط لتطبيقات نماذج ويندوز. 

يسمح لك من توليد متتبع ومخرجات تسجيل دخول للأغراض التسجيلية المسجلة.ویستخدم مع تطبیقات ۸8۲.۸٤۲‏ فقط . 
هذا الكائن مشابه لمخدم الصفحات الفعال ءعوم۴ إمرمS‏ مزا 4القديم الكائن اموه .وهو متاح فقط من أجل تطبيقات 
„ASP.NET‏ 

يوفر إمكانية وصول ديناميكي لتطبيق مخصص أو مصادر محلية مخصصة ومضمنة في التطبيق . 


الفصل الخاس mhm76‏ 


My.Response‏ هذا الكائن مشابه لمخدم الصفحات الفعال ءعوم۴ إم۷مS‏ مزا 4القديم الكائن م٣‏ مم5٠‏ .وهو متاح فقط من أجل تطبيقات 
ASP.NET‏ 
My.Settings‏ يوفر إمكانية وصول ديناميكي لنظام إعدادات التطبيJق .application settings system‏ 
My.User‏ یحدد مستخدم ویندوز rھوں‏ sسهه‏ م۷ الحالي»ویتضمن معلومات توٹیق .authentication information‏ 
My.WebServices‏ يیجلب تجمع لخدمات لويب nllتlحة available web services‏ لکي تستخدم في التطبيق.وهذه العقدة غير متاحة في تطبيقات 
„ASP.NET‏ 


يتضمن فضاء الأسماء الكثير من الميزات التي ستستخدمها بانتظام»من ضمنها الوصول لرقم نسخة التطبيقءبدلا من كتابة 
System. Reflection. whatever‏ 
للحصول على رقم النسخة التابعة للمكون الرئيسي ”هزه "“ءبإمكانك الآن كتابة فقط: 

My.Application.Info.Version.Major 
؟طيب جرب التالي:‎ ٥/٥٥٤0 هل تحتاج لقائمة من المجمعات»ءولكنك كسول جداً لأن تكتب الكلمة‎ 

My.Application.Info.LoadedAssemblies 
هل تحتاج لمعرفة الوقت الحالي بالنسبة للتوقيت العالمي أو في بريطانيا؟ جرب التالي:‎ 
My.Computer.Clock.GmtTime 

بإمكانك الاتصال بالشبكة المحلية re2 ew0٣)‏ اجعها:كما يلي: 


My.Computer.Network.IsAvailable 
من يشغل هذا الكمبيوتر على أية حال؟:‎ 
My.User.Name 


تتضمن أيضا الفيجوال بيسك الأمر "قتل ١ا"‏ الذي يسمح لك من حذف الملفات.تزيل الطريقة ماه ام N y.computer.۴ |8 Sys e.0‏ أيضا الملفات»ولكنها توفر 
خيارات إضافية من ضمنها أنها تسمح لك من إرسال ملف إلى سلة المحذوفات 81 ماعرمهR‏ بدلا من فقدانها بالكامل(للأبد). 


التوجيهات هي عبارات فيجوال بيسك»ولكنها فيما بعدءتصبح ليست كذلك. التوجيهان المفتاحيان اءمه#۳ و؟۴|# يوفران تعليمات للمترجم عن كيفية معالجة مقطع من 
الكود المصدري للفيجوال بيسك.(التوجيه الثالث هوه #8 »يساعد على جلب الكود المصدري ضمن الفيجوال أستوديو بشكل مرئيءولكن ليس له تأثير على المترجم 
أو على التطبيق المترجم النهائي) باستخدام التوجيهات»ءتستطيع إخبار المترجم على تضمين أو إخراج قطعة خاصة من الكود المصدري من المشروع النهائي. لذلك هي 
ليست عبارات كود مصدري للفيجوال بيسك حقيقيةءولكنها متاحة فقط في الفيجوال بيسك.ولكن لماذا تريد تضمين أو إخراج كود في تطبيق ما؟حسناءلعدة أسباب»على 
سبيل المثالءالنسخ المتعددة لتطبيقك»بالاعتماد على بعض الشروط فيمكن أن تشتري نسخة"سريعة ووعإم×م " ونسخة "محترفة اه٣0زووع؟‏ مم " لمنتج ما.معظم 
الكود يكون متشابه لكلا النسختين.وأيضاءيمكن للنسخة الاحترافية أن تتضمن ميزات غير متاحة في النسخة السريعةءأيضاءالنسخة السريعة يمكن أن تتضمن تقديم 
بسيط لميزة لديها استخدام أكثر تعقيد في الطبعة الاحترافية . 
بعض المنتجات البرمجية تحقق هذه الحاجة باستخدام شروط فيجوال بيسك القياسية. 
If (professionalVersion = True) Then‏ 
ShowWhizBangFeatures ()‏ 
Else‏ 
ShowLaughableFeatures ()‏ 
0 
إن هذا يعمل بشكل جيدءولكن مايزال التطبيق السريع يحتوي على الميزات المحسنة جميعها.حيث أنه فقط لايمكن الوصول إليها من أي كود»ءولما يتم تضمينه على 
سيدي التنصيب؟إذا استخدمت التوجيهات»تستطيع تخفيض س0ل )٣م‏ تلك المشكلة كأنها حلت.تستخدم التوجيهات التعابير الشرطيةء تشبه كثيراً الشرط 
Version = "rue‏ fessionaدrم‏ في مقطع الكود السابق.ولكن يتم تعريفها بواسطة العبارة #٥٥٣٤‏ ویتم استدعاء ثو ابت المتر جم .compiler consta۾ ns‏ 
#Const fullVersion = True‏ 
تعرف هذه العبارة ثابت مترجم منطقيا١‏ هاوه ۲عاام هع "اه8 .ويمكن للثابت أن يستخدم فقط مع التوجيهات»إذا حاولت استخدام هاو ه۷اانفي عبارة 
فيجوال بيسك قياسيةءفإن المترجم سيتذمر "اجام ه» .ولكن سيعمل بشكل جيد في توجيه ۴|# . 


HIE K(EUIlIVerSION — rue) IMen 
ShowWhizBangFeatures( ) 
#Else 


ShowLaughableFeatures ()‏ 
#End If‏ 
إن هذا الكود يبدو مشابه كثيراً لمقطع الكود السابقءولكن مع الإشارات # المضافة.فهما يبدوان نفس الشيء ولكنهما ليسا كذلك.مع سلاسة عبارة ۴|ءفإن الكود التالي 
سيتم ترجمته في التطبيق النهائي: 
If (professionalVersion = True) Then‏ 
ShowWhizBangFeatures ()‏ 


Else 
ShowLaughableFeatures () 
ERS ME 
نعم»كامل مقطع الكود.ولکن مع الموجهات»ما یتم تضمينه في التطبیق المترجم یعتمد علی قیمۂ اوم ۷ااںم.فإذا کانت ہ ٥ا٣٥ ۷ااںصواب مں۲۲ فإن التالي سيحصل‎ 


على الترجمة في التطبيق المترجم: 
ShowWhizBangFeatures ()‏ 


أما العبارات الأربع الباقية ستذهب»أي ستذهب أدراج الرياح»وكأنها لا توجد أبداً.ولكن في هذه الحالةءهذا شيء جيد.فالهدف كان الحصول على نسخة من المجمع 

المترجم خال(مجرد)من الكود الغير مطلوب(الغير مرغوب)»وهذا ما حصل. 

لوضع تابت المترجم اء ه۷|انلتوليد نسخة كاملة ماه اا ءفإنك تضمن هذا السطر عند أعلى ملف الكود المصدري والذي يتضمن مقاطع الكود؟|# الشرطية: 
eons EULIVEESIOR = E‏ 

عندما تكون جاهز لتوليد نسخة "سريعة"ءفقط غير كل هذه الأسطر إلى نظير ها "خطأً ما۴ ": 


CORSE EULIVESAON = HIL S® 
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شيء ما »يبدو أن تغيير هذا السطر في كل ملف كود مصدري عمل كثير »وهو كذلك.وماذا سيحدت إذا ما نسيت وضع واحد منها إلى النسخة المناسبة؟ بإمكاني 
إخبارك »أن هذا ليس بالجيد.لذلك توفر الفيجوال أستوديو العديد من الطرق لوضع ثوابت المترجم فور آءوتطبيقهم لك كجزء من التطبيق. الطريقة الأكثر شيوعا لعمل 
مثل هذا من خلال لوحة المترجم eاpi Com‏ التابعة لصفحات خاصيات lلnشu0رg project propertiesg‏ (شاهد الشكل التالي). أنقر علی زر خیارات المترجم المتقدمة 
Compile Options‏ Advanced»ومن‏ تم اعمل على إضافة ثوابت المترجم الشاملة الخاصة بك لحقل "ثوابت مخصص™صّڌة Custom constants‏ " 


Advanced Compiler Setings 


Uptimizationz 


Ll Remoaye integer overflow checks Enable optirmnizaliona 


DLL base address: ooo | 


leneralte debug info: pAb-only 


Lompilation Lonstants 


Ll Define DEBUG constant Define TRALEE constant 


Lustom constants: 


fally¥ersion = Tre 


Example: Hamel = Yaluel " Hamed='"Yalue2" Hame3= Yalue3" 
۷ءuها‎ 8عجsأع إلى هذا الحقلءتستطيع بناء نسخ مختلفة من التطبيق.يوفر مترجم الفيجوال بيسڭك‎ fuا/‎ Version = ۴aاse أو‎ fuا|‎ Versio = ۲٣ںe والآن بإضافة إما‎ 
أيضا ميزات تسمح لك من تثبيت صيغ ترجمة مختلفة وأمأإمء ماامهء tممامffاك لمشروعك.ولن أدخل ضمنها في هذا الكتاب»ولكن بإمكانك قراءة‎ cدmpiاeا‎ 
إذا كنت تريد هذا المستوى من الأدوات.‎ S8 ںاiا معلومات عنها من مستندات فيجوال أستوديو ضمن أدوات ل‎ 
يمكن لثوابت المترجم ءاہهاcons erاiنمmدc أن تكون أعداد ءإمطص نمأو سلاسل نصية ءو ”مء بالإضافة إلى الثوابت المنطقيةوم هم اهمع .بيئة تطوير الفيجوال‎ 
Define DEBUG " رlبتخا أستوديو تعين أيضا بعض توابت المترجم من أجلك. فالثوابت 0806و ع٣۸۸ ۲هي إما صح أو خطأً بالاعتماد على صندوق‎ 
الذي یظهر في الشکل السابق.‎ " Define TRACE constant و"‎ " constant 


في مشروع هذا الفصل رسميا سنتابع كتابة كود مشروع المكتبةءسنبدا بشيء ما بسيط:بناء المعلومات الأساسية حول التطبيق والفورم التابع لهءبما في ذلك رقم النسخة 
.version number‏ 

هدفنا هو الوصول لفورم ساحرة تنقل ورع۷٠هءالمعلومات‏ الأساسية حول البرنامج. 

مثل أي تطبيق فيجوال بيسك لويندوز»إنشاء هذه الفورم يتضمن خطوتين©1)إضافة الأدوات للفورم»و(2)كتابة الكود الخاص بها. 

Adding Controls تIودألا إضافة‎ 

إذا كان هناك مساحة يتفوق ءاععء×ه فيها الفيجوال بيسكءفهي إنشاء الفورم.يمكن أن يتم إنشاء البرامج بواسطة السحب والإسقاط للأدوات الجاهزة على سطح الفورم 
الجاهزة.وهذا كله يتم عمله من ضمن بيئة تطوير الفيجوال أستوديو المتكاملۂ)E¬|( !ntegrated Development Environment‏ المريحة والمناسبة.کما هو مبین 


فى الشكل التالى. 
ھا HESE E NT E Studio SO [Forrml.wh TT‏ 
File Edit Wiew Project Build Ûebug ÛData Tools Window Help “E *‏ ® 

AE BA dE -‏ ا 2 ا ا د ف ا@ ا - ك ج ف لوا 
Toolbox Solution Explorer HRH x‏ 


FE All Windows For ms 


E Com mon Controls 


EEE 


El WindawsApplicationl 


lk Pointer e EA) My Project 
Button i. EE] Forml.wb 
wÎ CheckBox 


E CheckedListBox 
Ed ComboBox 
TH] DateTimePicker 


© 


E roperties ee 
A LinklLabel Form1l System Windows, Forms.Forrm * 
EA ListBox 


EI EEE 

EH Size 300, 300 2 
Size Grip Style Auto 
snap ToGrid True 
startPosition Wir dows Defa ultL 


Sa Listwiew 

#-] MaskedTextBox 
EE fMonthCalendar 
Tî Matifylcon 

EA NumericUpDown 


Tag 
laê] PictureBox For m1 ا‎ 
EO ProgressBar Taphlast False 
(@ RadioButton Text 
2 Rich TextBox The text associated with the control, 
TextBox 
Ready 


تتضمن بيئة التطوير المعروضة أربع مساحات رئيسيةءوالتي وسمتها بالأحرف المبينة في الشكل في الأعلى: 
۸ .صندوق الاأدوات :×0 ط/ا٥٥٤‏ 


5 المجمعات 
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The form surface مروفll .سطح‎ B 

أي أداة هنا ليتم عرضها على واجهة المستخدم.والفورم " ما تراه هو ما تحصل عليه في النهاية /۷5|/۷6G‏ "لذلك فإنك تستطيع رؤية التصميم النهائي بالشكل 
The Solution Explorer Jalal فشكتwn. C‏ 

كل الملفات المتعلقة بمشروعك تظهر هنا.من أجل المشروع الحالي سترى فقط المدخلة †عمزه۴ ر" و المدخلة ٣۲ه؟ءط۷ ۶٥/1.‏ .يوجد عمليا ملفات أكثر.إذا 
نقرت على الزر الثاني من اليسار عند أعلى مستكشف الحلولءفإنه سيريك ملفات إضافية»ومعظم هذه الملفات يتم إدارتها بواسطة الفيجوال أستوديو من أجلك. 

The Properties panel صفئlصخئا‎ ili, D 

عندما تختار أداة على سطح الفورم»أو سطح الفورم نفسهاءأو أي بند في مستكشف الحلول»ستظهر خصائص البند المختار في هذه المنطقة.فتستطيع تغيير إعدادات 
العديد من الخصائص بكتابة إعدادات جديدة.بعض الأدوات تتضمن أدوات خاصة لمساعدتك في وضع قيمة الخاصية. 

سنعمل على إضافة ثمانية أدوات "عنوان وامطه| "ءوثلاث عناصر "شكل ممهمء" و"سطر هذا "«ارتباطي انترنٽ تzبıڍhyperlinksj‏ style-j«webزر‏ 
buttonءو‏ صورة picture‏ لسطح الفورم. 

اعمل على إعداد الفورم وذلك بضبط الخصائص التالية »انقر على سطح الفورم»ومن ثم عدل قيم هذه الخصائص باستخدام نافذة الخصائص: 


AboutProgram (Name) 


FixedDialog FormBorderStyle 


CenterScreen StartPosition 


بعدها»اعمل على إضافة تمانية أدوات "عنوان امطج | " لسطح الفور من صندوق الأدوات باستخدام الأداة " اeطھا".واستخدم‏ القائمة التالية لوضع الخصائص بالنسبة 
لكل أداة ١‏ 
عنوان. 


(Name): ProgramName Label1 
AutoSize: True 
Font/Bold: True 
Location: 136, 16 
مشرو ع المكتبة:×6]‎ 


(Name): Licenselnfo Label3 
AutoSize: False 
Location: 136, 48 
Size: 280, 32 
]٥×:صخرم غیر‎ 


(Name): DeveloperName Label5 
AutoSize: True 
Location: 160, 112 
Text: MHM 


(Name): DeveloperProject Label7 
AutoSize: True 
Location: 160, 144 

Text: In-book Project 


لنضيف بعض الأسطر والمقطع الملون للفورم .تتضمن الفيجوال بيسك6 أدوات أشكال مميزة للأسطر 5٥ہا|‏ »المستطيلات rectangles‏ »القطع الناقص ellipses‏ 
O O E O DG‏ الكود المصدري الذي يستخدم أوامر الرسم 
المخصصة لکن ذ محاكاة الأسطر والمستطيلات ت باستخدام أداة "عنوان Label‏ "قياسية »خالية sansمنj‏ النص . 


(Name): VersionDivider Label9 
AutoSize: False 
BackColor: Black 
Location: 136, 80 
Size: 280,1 
16×:) (لا تضيف أي نص‎ 
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(Name): BackgroundDivider Label11 

AutoSize: False 

BackColor: Black 

Location: 120, 0 

Size: 1, 296 

(لا تضيف أي نص ):ا×16 

إذا كانت أداة الأداة 11اعطجاتحجب الصورةءانقر يمين عليها ومن القائمة المنسدلة اختر "إرسال إلى الخلفية Sed ۲٥ 8a2»)‏ ". 
أداة"عنوان الوصلة إمطةا)مز_"مشابهة لأكثر أدوات العنوان الأساسيةامطم] »ولكن بإمكانك تضمین "'وصلات و)ہا| " في النلص»مقطع قابل للنقر clickable‏ 
5‰ اعم والذي يكون مشابه للوصلات على صفحات الانترنت.وسنستخدمها لعرض موقع ويب وعنوان أيميل.أضف أداتي " ا6 طة ا١ا"‏ للفورم واستخدم 
الإعدادات التالية لتركيب خاصيات الأدوات. 


(Name): CompanyWeb LinkLabel1 
AutoSize: True 
LinkBehavior: HoverUnderline 
Location: 160, 160 
Text: http://www.mhm.com 


الأداة الأخيرة التي سنضيفها هي زر والذي يسمح للمستخدم من إغلاق الفورم.أضف أداة زر ٣٥ا8‏ للفورم مع الخاصيات التالية: 


(Name): ActClose Button1 
DialogResult: Cancel 
Location: 344, 240 
Size: 80, 24 
]e×):قالغإ‎ 1 
يمكن أن يتم تركيب الفورم بحيث أن ضغط المفتاح ءءعيطلق أداة الزر على الفورم»وکان المستخدم ينقر على الزر نفسه عوضا عن ضغط المفتاح مع .لعمل هذا‎ 
Cance|lButton إلى مءهاع1ءA.لقد أجلنا هذه الخطوة حتى يتم إضافة الزر بشكل فعلي للفورم»إن الخاصية‎ عaءه|8‎ u اا٥ »انقر على سطح الفورم»وضع خاصیيتها‎ 
لن تسمح أن يتم إعدادها إذا لم يكن هناك زر موجود.حسناءوالآن ستبدو الفورم مناسبة »الشيء الأخير الذي أحب أن أعمله هو وضع ترتيب التنقلءالترتيب الذي يمكن‎ 
للمستخدم أن يصل به لكل حقل على الفورم عند الضغط على مفتاح "التنقل طج٠ " من لوحة المفاتيح.ولتحرير ترتيب التنقل»اختر سطح الفورم و اختر عرض سا۷‎ 
الأمر "ترتيب التنقل هل0۲ طه] "من القائمة.كل أداة على الفورم التي يمكن أن تأخذ قيمة ترتيب تنقل سيكون لديها ترتيب تنقل بجانب كل منها.‎ >> 
انقر على كل عدد أو أداة بالترتيب حتى تحصل على الترتيب الذي تريده.(شاهد الشكل التالي لترى كيف رتبت الأدوات).أخيراءاختر عرض ۷ه۷1>> أمر ترتيب‎ 
التنقل مل0 ط2٦ مرة أخرى »أو اضغط المفتاح عع لمغادرة عملية ترتيب التنقل.‎ 


عشروع التك8] 
اداد س .ع التق دع 
غير مراک 


تصت البرصجة E...‏ 


Er 


ESgramming isal Basic ZUNE 
Ebook Project 

EC fs, kimaki, com 
EKlIBtimaki.com 


EE right {cj 2009 by MHM 


تنتظيع ايا وع تر تيب الققل لكل بتعدیل خا ×هل اط 7ءولكن الطريقة الأسرع التي هي التي قمنا بها للتو. 


والآنءحان الوقت المناسب لإضافة بعض كود فيجوال بيسك الحقيقي.لنأخذ نظرة سريعة على مستكشف الحلول»انقر زر "أظهر جمیع الملفاتوم‌Fi|l Show All|‏ 
"عندما تظهر جميع الملفات انقر على إشارة الزائد بجانب ط1.۷١۳١٥٠۴ءوأخيرآءانقر‏ مزدوج على ط#۲.۷١واوه ٠۲1.50‏ ۴(شاهد الشكل التالي). 
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نظرا لكونها أكثر من 200سطر من الكود المصدري »فلن أطبعها هناءولكن انظر إليها بشكل عام»فعندما تعمل على سحب وإسقاط أدوات على الفورم وتعدل 
خصائصهاءتعمل الفيجوال أستوديو على تعديل هذا الملف من أجلك.وهو جزء من فئتك للنموذجءءهاع ۴٥۲٣٠٠‏ (جميع النماذج هي فئات يتم اشتقاقها من 
orm‏ stem.Windows.Forms.FرS).بإمكانك‏ أن تعلم ذلك بواسطة الكلمة المحجوزة اهنا جم عند الأعلى . 
EaEElal Class ADOUEEBEOGTE aM‏ 
Inherits System.Windows.Forms.Form‏ 


- |] Wy Project 
lî] References 


a EE Foml.wb 
pj Kormi.Designer.wb 
Î Forml.resx 


يحدث معظم الفعل في الإجراء أ١٠”ممصهعهzااهناام|.‏ عندما تنتهي من إلقاء نظرة شاملة عليه ككل أغلق مصمم الكود وارجع إلى سطح الفورم. 
لجعل نموذجنا نموذج حقيقي وممتع»ءنحتاج لعمل ثلاث أشياء: 

ه إظهار رقم النسخة الحقيقي للتطبيق.وسوف يتم تحديده وعرضه عندما تظهر الفورم للمرة الأولى. 

ه الذهاب إلى موقع الانترنت المناسب أو متلقي الايميل المناسب عند النقر على لوحة الوصلة.وهذه الأحداث يتم معاملتها في حالة الاستجابة لفعل المستخدم. 

ه إغلاق الفورم عندما ينقر المستخدم على زر الإغلاق. وهو أيضا حدث مقاد من قبل المستخدم. 
لبد بالأسهل »إغلاق الفورم»فالأحداث هي مقاطع من الكود يتم معالجتها في حالة الاستجابة لشيء ا الأغلب إجراء مستخدم مثل النقر بالفارة.كل 
الإجراءات التي نريد أن ننجزها على هذه الفورم ستكون رد فعل (استجابة) على الحدث المطلق(المحرر). الطريقة الأسهل للوصول إلى الحدث الافتراضي للأداة هو 
بالنقر المزدوج عليها.جرب هذا الآن على الزر.عندما تنقر مزدوج على الزر فإن بيئة التطوير ستفتح محرر الكود(الكود المصدري) »ستضيف معالج حدث 
فار غ(الإجراء الفر عي (ActClose_Click‏ 

EUOIlNE Class ABOULEEOGE AM 


End Class 
يذلاورءender لمعاملات النسبية10)المعامل النسبي‎ ١ ع حدث معتمد على النماذج(وفي الحقيقة »معظم أنواع الأحداث الأخرى)في الدوت نت لديها نسبيا نفس‎ 
يشير إلى الكائن الذي أطلق هذا الحدثءو (2) المعامل النسبي هءوالذي يسمح ل 6۲ل" 6ءمن التزويد بأي معلومات إضافية يمكن أن تكون مفيدة في الحدث.في هذه‎ 
بما أنه الكائن الذي سيولد حدث النقر اا۳ .وحدث نقر الزر ليس لديه أي معلومات إضافية‎ A٤٥6 إلى الزر‎ ریشیسs‌en‎ der الحالة »المعامل النسبي‎ 
»والذدي یکون نسبیا حاجز مکان ۲ ٥لاه مع ھام»وهو الكائن الذي منه کل آنواع المعاملات‎ « System. Eve n†Argsaضا|رتفالا م هو نوع الكائن‎ كلذل٬ةحاتم‎ 
النسبية هالأكثر أهمية تستمد (نشدَق منه).‎ 
اسم معالج الحدث هذا هو )زا٣ _مءه|ا٣†ء^ءولكن إذا كنت تريد تغيره إلى أي شيء تريد ءفإنه لن يفقد أي شيء.ولكن عليك أن تحفظ التعبير(عالج نقر.الزر‎ 
وهذا هو الجزء الذي يربط معالج الحدث ۲٥ال١" ةط م۷ بالحدث الفعلي.‎ . intaعاةميلس)Handاes‎ ActClose.Click 
والكرة اللارم لأغلاق الفررم بيط جد أمخله الأن اة ساره‎ 
Private Sub ActClose_Click (ByVal sender As System.Object, ByVal e As System.EventArgs) Handles 
ActClose.Click 


ERG SUS 
تقول هذ. الجارة ©5105[ (إني نموذج /كائن المشروع حول البرنامج»وآمر نفسي بالإغلاق.)إذ شغلت البرنامج الآن(اضغط ۴5)ءإنك تغلق الفورم بالنقر‎ 
على الزر "إغلاق".بما أن نموذج المشروع هو الفورم الوحيد في التطبيقءفإن إغلاقه يؤدي بشكل آلي إلى إنهاء كامل التطبيق.‎ 
ارجع إلى البند الثاني »وصلات الانترنت. بإمكانك العودة إلى سطح الفورم والنقر المزدوج على كل لوحة وصلة لإنشاء معالج حدث لكل أداة لوحة وصلة‎ 
أا).ولكن بإمكانك أيضا إضافة الإجراء الفرعي لمعالج الحدث من ضمن المحررءإما بكتابة الكود نفسه(وهذا غير‎ ٥اه)‎ ١ افتراضي(في هذه الحالة»حدث‎ 
مناسب) أو باستخدام قائمتي الانسدال فوق نافذة المحرر(شاهد الشكل التالي)‎ 
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S WindowsApplicationl - Microsoft ¥Yisual Studio 


File Edt Wiew Project Euildl Debug Data Tools Test Window Help 

ER Ela EL Ekle Se E El 

Toolbox = ‘Forml.¥b 7 Form1.Designer.vb | Form1.4vb [Design] | i 
l= General : 
g# AeIClose ا‎ #۴ Click مه‎ 


There are no usable controls 
in this qroup. Drag arı item 
onto this text ta add it lo the ûA,boutPrograrn Events] Click {(BYYal sender As System 


taolbo#. 
em. EventArgs] Handles 


BackgroundDivider 
BackgroundS ide 
LampanyCaopyright 
L-ompanyE mail 
Lompanyeb 
DewelapedBy 
LerelaperB ook 
Developer arme 
DeweloperProject 
Licenselnfo 
Prograrn arme 
Prograrmiyersior 
9# E 


zaaıros, BEG L1 1a10d#3 UoHH|OS Ê 


a Server Explorer] | 


4 Error List) 


ltem|s] Saved 


تظهر قائمة اسم الفئة(الكائن) في الجهة اليسارية.اختر أي مدخلة من هذه القائمةءواختر الحدث المناسب من القائمة اليمينية(قائمة اسم الطريقة ك 60~ 


CEI 


NName).ولإضافة‏ قالب معالج حدث لحدث ic)edاC Link‏ CompanyWebsختر‏ أو طc0ompanyWe‏ من قائمة اسم الفئة اليسارية»ومن ثم اختر من 
القائمة اليمينية (قائمة اسم الطريقة).وبالتالي سيظهر مقطع الكود التالي: 
Private Sub CompanyWeb_LinkClicked (ByVal sender As System.Object, ByVal e As‏ 
System.Windows.Forms.LinkLabelLinkClickedEventArgs) Handles CompanyWeb.LinkClicked‏ 


ا 
قائمة المعاملات النسبية لهذا القالب نوعا ما أكثر إثارةءحيث أن المعامل النسبي ههو كائ yi ja‏ ع: EventArgs.‏ aû.System.Windows.Forms.LinkLabelLinkClickedح‏ 
لك الأداة امطةا )ما من أن يكون لديك عدة وصلات انترنت في أداة وحيدة» موز عة ل ۲568 8۲56| بين نصوص نظامية.للمعامل النسبي عمخاصية "الوصلة )ہز | " والتي 
تخبرك أي من الوصلات في الأداة تم النقر عليها من قبل المستخدم.بما أن لوحاتنا ئkەلهالها‏ فقط وصلة وحيدةءفلن نعاني في اختبار ها.سنظهر فقط صفحة الويب مباشرةٌ في أي 
وقت يتم النقر على الوصلة. 
Private Sub CompanyWeb_LinkClicked (ByVal sender As System.Object, ByVal e As‏ 
System.Windows.Forms.LinkLabelLinkClickedEventArgs) Handles CompanyWeb.LinkClicked‏ 


End Sub 
الكائن ءءعع ه٣۴ هو جزء من فضاء الأسماء sعنأومموهm.0iمSystءر اStarهي واحدة من أعضاءه المتشاركة والتي تتيح لك من تشغيل تطبيقات ومصادر خارجية.إنك تمرر له‎ 
أي عنوان انترنت #1 لامناسب وهو سيشغله باستخدام مستعرض المستخدم الافتراضي أو التطبيق الخاص بعناوين الانترنت 81ل .لنجربه مرةٌ أخرى مع حدث‎ 
. قالبه بأي طريقة تختارها ومن ثم اكتب أو أدخل الكود الذي يشغل رسالة جديدة لعنوان الايميلااة"6‎ فضأ.companyEmaiاs‎ Link Clicked 
Private Sub CompanyEmail_LinkClicked (ByVal sender As System.Object, ByVal e As 
System.Windows.Forms.LinkLabelLinkClickedEventArgs) Handles CompanyEmail.LinkClicked 


HRA SUG 
:الحدث تحميل 4ج0 ].ويتم استدعاءه تماما قبل أن تظهر الفورم على‎ ٤0۲" الحدث الأخير الذي سنصممه هو واحد من الأحداث الأولى والتي يتم استدعاءها في دورة حياة الفورم‎ 
الشاشة.انقر مزدوج في أي مکان علی سطح الفورم وهذا سينشئ قالب معالج الحدث الخاص بحدث التحميل.(بإمكانك استخدام نافذة محرر الكود ومن قائمة الفئة قي الجهة اليسارية‎ 
.) أعلى نافذة المحرر اختر الفورم ومن قائمة الطرق في أعلى اليمين اختر الطريقة تحميل لةه ا‎ 
.System.Version »و هي نسخة (حالة( منj َة‎ My. Appاication.|nf]‎ 0o. Versio" لنضيف لهذا الحدث الكود الذي سيعرض رقم النسخة الصحیح»باستخدام‎ 
Private Sub AboutProgram_Load (ByVal sender As System.Object, ByVal e As System.EventArgs) Handles 
MyBase. Load 


EA SUS 


يستخدم هذا الكود العبارة ۸ ۷لتخفيض كمية الكتابة المطلوبة في عبارة الإسناد الرئيسية.داخل عبارة W۷)‏ "...ءيس هناك حاجة لإعادة كتابة اسم 
الكائن الذي يظهر تماما بعد الكلمة المحجوزة ۷)۸ءفي هذه الحالة ٣مأrs f0. Ve‏ ication.|nاMy.App.بإمكانك‏ الإشارة لأعضاء ذلك الكائن بكتابة النقطة 


اق اناف 


وضع رقم النسخة 
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إذا شغلت البرنامج٬فإنه‏ سیعرض رقم النسخة المحددة حاليا”,0 “1.0Revİsion‏ کما هو مبین في الشكل التالي: 


مشروع العكنبة 
wersionl .Urewisianl‏ 


سؤالي»هو"أين يتم تحديد رقم النسخة هذاءوكيف استطيع تغيره؟"يتم تخزين قيم الإصدار كميتاداتا(توصيف بياناتهاة لهه" ) ضمن المجمع.تتضمن الفيجوال 
أستوديو نموذج يسمح لك تعديل الميتاداتا المعلوماتي الأساسي المخزن في المجمع.للوصول للفورم»اعرض خصائص المشروع(أنقر مزدوج على اءهزه۴ My‏ في 
مستکشف الحلول)»واختر تبویب ٥۸‏ امم A‏ »ومن تم انقر على زر 0۸أأة"٣۲ه؟ما‏ رااصهءءA‏ (شاهد الشكل التالي)يستخدم نموذج تطبيقنا رقم النسخة »والذي 
تم وضعه باستخدام أربع حقول نصية بجانب ملصقة إصدار المجمع.وهذه الحقول الأربع تمتل أرقام المجمع ‘Minor «Major‏ Buildءر‏ NRevision.بإمكانك‏ 
تغيرها ومن ثم نقر موافق 0۸ ومن تم شغل التطبيق. 


Assembly Information PK) 


Title: Windows Applicationl 
Description 

Lompany: rnsk 

Product: WindoysA, pplication 
Lopyright: Lopyriaht & mat 2O3 


Trademark: 


Assembly Yersion: | 0| 0| 
reves Û | 1 | | 
au 


Heutral Language: | [None] 


L_l Make assembly COM -Wisible 


على الرغم من أن هذه النموذج مريح»فهو عبارة عن مثال أخر لكتابة بعض كود مشروعك بالفيجوال أستوديو بالنيابة عنك.كل حقل على هذا النموذج يتم حفظه في 
ملف الكود المصدري المضمن في مشروعك.لعرضه»ءتأكد من أن الزر "أظهر جميع الملفات ۴|٥5‏ ال۸ سهط؟ "مازال مختار في مستكشف الحلول Solution‏ 
orerاEx>p‏ .مدد بند tهزم۴۲ 1y‏ باستخدام إشارة الزائد»ومن تم انقر مزدو ج على بند ۷ .۲0١//”/776/عءئ4‏ .هذا الملف يعرف عدة مواصفات خاصة بالمجمع 
attributes‏ specific-yاembهssه‏ (وسنستكشفها في الفصل 18)»إنه يتضمن المدخلات العملية التالية: 


Imports System 

Imports System. Reflection 

Imports System. Runtime. InteropServices 

'"' General Information about an assembly is controlled through the following 
' set of attributes. Change these attribute values to modify the information 
' associated with an assembly. 

' Review the values of the assembly attributes 


AssemblyTitle ("LIBRARY") > 
AssemblyDescription ("") > 

AssemblyCompany ("mst") > 

AssemblyProduct ("LIBRARY") > 
ASSeMOIYVECE OPYEI AE (LCEoOPVEIORE O MSE 200O) 
AssemblyTrademark ("") > 

ComVisible (False) > 


<Assembly: 
<Assembly: 
<Assembly: 
<Assembly: 
<Assembly: 
<Assembly: 
<Assembly: 


ihe Following GUID 15 Eo the 1D OE the CtyBelID 1E CRIS PrONeCE 18 exposed EO COM 


Guid ("44d7c504-bcd1-4d64-89fe-bbf91d2e1875") > 


<Assembly: 


1" VEESiION InEOEMaAEION FOE al asseNbly CONSISES OE Ehe FOllLOWIDNG EOUE Values: 
Major Version 

Minor Version 

Build Number 


You can specify all the values or you can default the Build and Revision Numbers 
by using the l1 48 SAOWN DELO: 
<Assembly: AssemblyVersion ("1.0.*")> 


AssemblyVersion ("1.0.0.0") > 
AssemblyFileVersion ("1.0.0.0") > 


۳ 
U 
1 Revision 
۳ 
9 
N 


<Assembly: 
<Assembly: 


کما تری»هذا الملف تم تحديثه بواسطة القيم التي کتبتها ضمن نموذج معلومات المجمع. هل تشاهد مواصفة AssemblyVersionالمعرفة‏ هنا. ذا عدلت هذه القيم»فإن التغيرات 
ستنعکس في نموذج معلومات المجمع»وأيضاً في تطبيقك المشغل وأخيراً قي المجمع المترجم.إحفظ العمل من (ملف <<File‏ حفظ الجميع Save All‏ ( 
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٤ 
2 
٤ 


بقدر الفائدة والمواصفات الكثيرة في نموذج "۳ ه9۲١٣1۴اهط4الذي‏ عملناه حتى الآن فإن مثل هذا النموذج نادرآً ما يكون عليه التركيز الجوهري لتطبيق ما.في 
مشروع المكتبة »سيتم عرض هذه الفورم فقط عندما يتم طلبها من الفورم(النموذج)الرئيسي ”آج1 ءلذلك لنضيف فورم رئيسي بسيط الآن.في الفيجوال أستوديو»أختر 
مشرو ع cھزہ٥P‏ >>إضافة نموذج ویندوز W۸۵0 W8 ۴0٥۲۳‏ ۸4d4.عندما‏ یظھر حوار إضافة بند جدید )ا Add ٥W‏ ءأختر نموذج ویندوز 0wsلہWi‏ 
۴0۳ من بنود القائمة المتاحة»و سمه ا۸۴0۲۳.۷ اج" قبل النقر على زر إضافة ١ل١۸.‏ 

من نافذة الخصائص خصص الخصائص التالية كما هو مبين في الجدول التالي: 


MainForm (Name 


) 


False MaximizeBox 


Text‏ 1 مشروع 1 تد لمكتبة 
من صندوق الادوات أضف أداة E‏ للفورم بالخصائص التالية: 


ActHelpAbout (Name) 


Text‏ ګحول... 
الحرف الخاص& يعمل على وضع اختصار لاع)۲ه مء للزر.عندما تضغط على مفتاح مع الحرف الذي يتبع”&“ (في هذه الحالة حرف ح)فإن البرنامج سيتصرف وكأنك نقرت 
على الزر بواسطة الماوس. 
انقر مزدوج على الزر وأضف الكود التالي لإجراء حدث النقر: 
Private Sub ActHelpAbout_Click (ByVal sender As System.Object, ByVal e As System.EventArgs) Handles‏ 
ActHelpAbout.Click‏ 


ا ا6ا 
هنا خصصنا مؤشر مباشر للنموذج ۴۲١9۲4۳‏ هطA.‏ قبل الإصدار 2005 من الفيجوال بيسك»كان إظهار الفورم يتطلب إنشاء حالة(نسخة) من فئة الفورم قبل 


إظهارها: 
(New AboutProgram) .ShowDialog( )‏ 
هذا التركيب مازال يعمل»وهي الطريقة المعتمدة إذا كنت تريد عرض عدة نسخ من نفس الفورم على الشاشة في نفس الوقت.مهما يكن التركيب 
) (giAboutProgram.ShowDialogضح‏ بکثیر للاستخدام المفرد للنماذج»ویعکس عن قرب كيفية تقدیم الفورم .عملياء هذه العبارة تستخدم فضاء الأسماء 
1¥ .العبارة الكاملة تبدو مشابهة للتالي: 
My.Forms.AboutProgram. ShowDialog ()‏ 
يسمح لك التجمع 5 "0۷.۴0۲۳ من الإشارة إلى أي فورم ضمنه دون أن يكون عليك الكتابة في البدايةئ" 1۷.۴١۲‏ .أعضاء التجمع تمثل الحالات الافتراضية 
eau instances‏ لکل نموذج في المشروع. 
هذا كل الكود الذي نحتاجه حالیاءولکن إذا شغلت التطبیق «فإنه مایزال یعرض فقط الفورم 0u 1۴۲٥9۲2۳‏ ظ۸. هذا لأن الفورم ۴٣٥9۲2۳‏ u٥0طۃ‏ قد تم وضعھا 
كفورم بداية التشغيل ”ماهو“ .لتبديل هذا »افتح نافذة خصائص المشرو ع هااا همهم ء'اءهزم۲م»واختر تبويب ١10أهء‏ اام م۸ تطبيق وضع حقل"فورم بداية 
llتشغيJ MainForm " yl! " Startup form‏ " 
سيتم الآن عرض الفورم 1۴۲١9۲4۳‏ uمطAكفورم"حوار‏ وه‌اها "(من خلال استدعاءها بالطريقة وماةاS0W5)كل‏ فورم تتضمن الخاصية 
ااResu ial‏ والتي يتم إرجاع قيمتها بواسطة الطريقة وهاه2i‏ س50 عندما تغلق الفورم. كل زر ١٥ا‏ اطعلى نموذجك يمكن تركيبه لإسناد هذه الخاصية 
بشکل آلي ویغلق الفورم.فالزر "إغلاق "على الفورم 01۴۲٥9۲4۳"‏ ط۸يعمل هذا تماماءفخاصيته اوم8 وهاه0iتم‏ إسنادها إلى "إلغاء اعمج "»ءوالتي تم 
إسنادها إلى خاصية الفورم اوم8 وه اه0 عندما ينقر المستخدم على زر "إغلاق".كتأثير جانبيءفي أي وقت القيمة(مالم تكن لاشيء)يتم إسنادها إلى خاصية 
tاResu (ial‏ النموذج »وتغلق الفورم. 
الحصيلة اهوم رمن هذه الفقرة الطويلة هي أنك تستطيع الآن حذف معالج حدث النقر على زر الإغلاق»ءوسيبقى الزر يغلق الفورم.احذف الإجراء 
Act Cا0se_ Click‏ من الكود المصدري للنموذج 1۴۲٥9۲4۳‏ uهط۸‏ .«شغل البرنامج ولاحظ ما يحصل.الزر إغلاق مازال يعمل على إغلاق النموذج 
AboutProgram›حتى‏ بدون معالج الحدث. 
بإمكانك أيضا ترك الإجراء في مكانه »واعمل على تنظيف خاصية اوم8 وه اها للزر "إغلاق" وأضف العبارة التالية لمعالج حدث نقر الزر: 
Me.DialogResult = Windows.Forms.DialogResult.Cancel‏ 


هذه ثلاث طرق مختلفة نستطيع بها إغلاق الفورم 9۲2۳١۸6011۴۲.يوجد‏ عدة طرق أخرى مختلفة لإتمام نفس المهمةءلذلك كن مبدعاً. 


لإضافة أيقونة مخصصة للفورم الرئيسي.اتبع الخطوات التالية: 

1.أعرض الفورم الرئيسي بالنقر المزدو ج على البند ا0۲۳.۷ 2i۴‏ في مستکشز Solution Explorer Jgl>ll‏ . 

2.اختر سطح الفورم 

3.اختر خاصية 0٠۸١‏ |للفورم في نافذة الخصائص كءع|)eم0٣۴.‏ 

4.انقر الزر "..." في هذه الخاصية »وابحث عن ملف في الدليل الفر عي للفصل الخامس»ءبإمكانك أيضا استخدام أي ملف أيقونات 0/. . 


٣ 
٣ 
٣ 


الفصل السادس:البيانات وأنواعها. Mhm76‏ 


البيانات lgiİyعl Data and Data Types‏ 
سنناقش كيف تستخدم وتعالج الفيجوال بيسك البيانات ضمن تطبيقاتك»وكيف تستطيع تسيد الأدوات التي تجعل هذه المعالجة ممكئة. 


في الفصل الثاني ذکرت کیف تتحلل جمیع البيانات في الكمبيوتر ضمن بتاتات(وحدات bits‏ ( مستقلةء النبضات الكهربائية التي تمثل إِما 1 أو 0“ أو fگە»صواب‏ 
مأو خطاً هءاهf.‏ بما أن نظام الأرقام العشرية يتطلب أكثر من هذه القيم فقطءفإن الكمبيوتر يعمل في عالم من الثنائيات-نظام الأعداد المحدودة لرقمين 0و 1. 
لحسن الحظمن السهل جد تمثيل الأعداد العشرية الصحيحة الأساسية باستخدام مجموعة رموز الثنائي. 


لاحظ الشكل التالي الذي يبين قيم الأماكن المختلفة للأعداد المتعددة الأرقامءنفس النوع من التخطيط يمكن أن يتم استخدامه من أجل الأعداد الثنائية ءفقط أسماء وقيم 
الموضع يتم تغير ها.من أجل الراحةءندعو هذه المواضع بأسمائها العشريةءأو نستخدم ما يتعلق بالأساس 2.وكل هذا مبين في الشكل التالي: 


ست عشر(“16=2) 


| انان وثلائون(32=27) ا وثلاثون(2°= | انان وثلائون(32=27) ا 


کے اس 
[rr] L4‏ 


موضع"8بت"8ارقام لعدد ثنائي. 
لاستكشاف ما هو الرقم المقابل في النظام العشري.فقط اجمع الأعمدة.لنرى ذلك»يوجد واحد في الموضع الثاني والثالث»وفي الموضع 
السادس أيضاًء ولاشيء(صفر في باقي المواضع كما هو موضح في الرقم الثنائي 01001100 ولحساب قيمة كل موضع كما هو مبين في الشكل السابق 
نرفع الموضع إلى قوة(أس) الموضع بالنسبة للأساس2)ومن تم نضرب كل قيمة لهذا الموضع بالقيمة الموافقة في العدد الثنائي ومن ثم نجمع النتيجة لنحصل على 
الرقم العشري الموافق كما يلي: 
76=128×0+64×1+32×0+16×0+8×>1+4×1+2×0+1×0 وهو العدد العشري المقابل للعدد الثنائي. 
بما أن أي رقم ثنائي لايمكن أن يكون أكثر من 1ءفالعد بسيط جدا.لقد بينت مثال عن 8-بت(8-رقم)ثنائي هنا-والذي بدوره بإمكانه معاملة الأعداد العشرية من0 
حتى255 ولكن إمكانك تمثيل أرقام عشرية أكبر بإضافة أرقام تنائية أكثر.ولكن هذا مناسب من أجل القيم العددية الصحيحةءفكيف ستمتل الأعداد العشرية والكسرية؟ 
وماذا حول الأعداد السالبةءفي أي مكان ستكون مناسبة في هذا النظام الثنائي؟فهي ليست مجرد أعداد.فحاسبي بإمكانه معالجة البيانات النصية»مصفوفات 
الأعدادالصور الرسوميةءوسجلات مخصصة.فكيف تم تخزين مثل تلك الأشياء في النموذج الثنائي؟لمعالجة آلاف من النماذج البيانيةءكل كمبيوتر يتضمن مجموعة 
صغيرة من الوحدات المتناهية في الصغر والتي تكون مناسبة بالنسبة للرياضياتءاللغةءوالفن. 
تنفذ الكمبيوترات "أنواع البيانات وعمرئ واج "لمعالجة جميع النماذج المتنوعة من البيانات لكي تكون قابلة للإدارة.يتصرف كل نوع من أنواع البيانات وكمفسر 
(مترجم۲٥اعامrھtہi‏ ) بین تجمع من البتات وقطعة من المعلومات التي يستخدمها لكمبيوتر بحيث يستطیع مستخدم الكمبيوتر من فهمه والانتفاع i7eاutiمنه‏ أفضل. 
أخيراً yاtimateاuتخزن‏ أنواع البيانات محتویاتها كبتات مستقلة من البيانات.ولكنها تختلف في كيف يتم ترجمة(تفسير) هذه البتات.تصور نوع 
بيانات اسمه فيتامين" "۷|8 والذي يحدد أي فيتامين تم تضمينه في منتج طعام.يبين الشكل التالي كيف يمكن إسناد 8-بت المستخدم 
سابقاً وتفسیره(ترجمته) کالفیتامینات. 
مع وجود نوع بيانات»بإمكانك إسناد قيمة فيتامين لبند طعام موجود في تطبيقك.(مجرد مثال ) 


Vitamin B1 Vitamin E 


Vitamin B2 Vitamin 0 
Vitamin B6 Vitamin C 
Vitamin B1 | 0 ™ A 


01001100 


خذ العدد 76 الذي ناقشناه سابقآء فهو سهل التحويل جدآً إلى التمثيل الثنائي» كما في 01001100.يتضمن إطار عمل الدوت نت عدة أنواع 
بیانات تقوم بمثلٍ هذا التحويل بشكل آلي»تختلف فقط بالعدد المكون من أرقام تنائية(بتات) التي يمكنها معالجتهاءفي عالم الكمبيوتر »يمثل 76 
أيضاآً حرف من الأأبجدية-الحرق الكبير /.وهذا لأن هناك نوع بيانات يؤسس قاموس بين القيم الثنائية والحروف الأبجدية(والرموز الأخرى) 
.تستخدم برامج ويندوز ولمدة طويلة الآسكي//٤48‏ (الكود الأمريكيِ القياسي لتبادلJ‏ |Jمeعlلgمlٽت American Standard Code for Informati0¬‏ 
eوnterchnanا)وأعدادها‏ إلى وبالعكس كقاموس الحروف.فكيف تحول أنظمة المستندات 8-بت هذه الأعداد من 0 إلى255 إلى كل الحروف 


1 البيانات وأنواعها. 


المتنوعة المستخدمة في اللغة الإنكليزية» ومن ضمنها علامات الترقيم ١0ااةںاء"اموالرموز(الحروف)الأخرى‏ المتنوعة miscellaneous‏ 
.characters‏ 

قاموس أخر. يونيكود 0/٥0۵٥‏ يستخدم 16-بت من البيانات لمعاملة حوالي65,000حرقف مختلف.تستخدم الدوت نت اليونيكود من أجل حروفها 
وأنواع بيانات "السلاسل النصيةوہ ]اء " : 

يوجد نوع بيانات اخر وهو المنطقية 8001621 »والتي تستخدم بت مفرد اط eاوہاء‏ لتمثیل إما صواب ۲٣۵‏ (بت ذو قيمة 1)او خطا ٥ا۴‏ 
(0).القيم العددية الصحيحة السالبةكe۲‏ ومام Negative‏ .والعشرية ذات النقطة العائمة point-liJlgfloatingبتة dates خıرlوتllو «fixed-point‏ 
والوقت كئهصiاوالتي‏ تدور خارج أنواع البيانات القاعدية على الأغلب تدار بواسطة الحاسبات وتطبيقاتها.يمكن أن يتم بناء بيانات أكثر تعقيدآً من 
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أسماء النظام #۳اءرك.أحد أنواع البيانات هذه هو مار8."ءاءر8, والذي ينفذ 
قيمة عددية صحيحة 8-بت»تماماً کما ناقشناه سابقاً .فهو ھا قيم عددية صحيحة من 0إلى255 .وهذه القيم يتم تخزینها دائماً باستخدام8بت 
من البيانات الثنائية»ولكنها تظهر بطريقة سحرية في النموذج العشري ٥۲١‏ اة"٣أءهك‏ عندما تريد إحضارها. 

ES‏ إطار عمل الدوت نت 15 من أنواع البيانات التفسيرية الجوهرية؟همرا مجه مtivمامinte coe‏ :8أنواع للبيانات العددية الصحيحة 
integers‏ 3أنواع للأعداد العشريةك۲ءطاصن" امصاعمهل .2نوع للبيانات الحرفيةهأةل ۲عاعماcna‏ .نوع بيانات موحد للتواريخ والوقت ك2 dates‏ 
ties‏ وأخيرآً نوع البيانات المنطقية1 800164 . 


تعتمد على عدد انواع البيانات المتاحة(8من بين الأنواع الأساسية ال15 )»يمکن أن تعتقد أن معظم المبرمجين يعملون طوال اليوم مع الأعداد 
الصحيحة»ويمكن أن تكون محق.سواء كانت بيانات المستخدم الفعلية أو عداد حلقة أو كود مرحلي أو طرق تخزين لأنواع البيانات 
المعدودة(المحصية). تظهر البيانات العددية الصحيحة في كل مكان ضمن كود الدوت نت.يعتمد مجال القيم بالنسبة لنوع البيانات العددية 
الصحيحة مباشرة على العدد من الأرقام الثنائية المدارة بواسطة نوع البيانات. كلما كانت الأرقام أكثر » كان المجال أكبر.وأيضاً النصف من أنواع 
البيانات العددية الصحيحة تخزن كلا من القيم الموجبة والسالبة(تدعى الأعداد الصحيحة ذات إشارة كا#وعام! ”۹١ه”واء“).بينما‏ النصف الباقي 
يدعم فقط الأعداد الموجبة(بدون إشارة١#٠وأءمں‏ )تجدول القائمة التالية أنواع البيانات العددية الصحيحة المضمنة في الدوت نت»ءوما يصاحبها 
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0 to 255 Unsigned 
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-2,147,483,648 to 2,147,487 Signed 
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-9,223,372,036,854,7 75,808 Signed 
to9,223,372,036,854,775,07 


أنظر إلى هذه الأنواع بطريقة أخرىءيبن الجدول التالي العلاقة بين الأنواع وعدد البتات التابع لكل منها ونمط المجال: 


8-bits 16-bits 32-bits 64-bits 
Signed SByte Int16 Int32 Int64 
Unsigned Byte UInt16 UInt32 UInt64 


عندما جاءت الكسورك"هااع ه۲ » لم تكن في البداية سيئة»بما أن العديد منها يمكن أن يتم تحويله إلى نموذج عددي بسيط بادخال 
الفاصلة(النقطة) العشرية في العدد:2/1 يصبح0.5ء و4/1 يصيح أطول ولكن يبقى أصغر 0.25 »و3/1 يصبح ... 0.33333 ماالذي يحدٿ هنا؟لا 
أستطيع كتابة كل هذه 3.وإلا سيصبح الكتاب 2,000 صفحة أو أكثر.أخيراً»اكتشف الناس أنه في عدة حالات»فإن كتابة كل 3 لايستحق 
العناء.لذلك فإنهم توقفوا عند بعض النقاط. كما في EEE‏ .0. 

هذا ليس بالدقة الكاملة»ولكنه جيد بما فيه الكفاية»وهذا هو الحال بالنسبة للقيم العشرية المعتمدة في الكمبيوتر computer-based decimal‏ 
ئ6 يمكن أن تمتلك دقة تامة حتى نقطة معينة.بعد ذلك»يقع عليك اختيار ما هو جيد بشكل كافي بالنسبة لك.يتضمن إطار عمل الدوت نت 
تلات أنواع بيانات عشرية. اتنان منهما يقبلان دقة محددة بدلاً من المجال الكبير من القيم.والثالث لديه دقة تامة(مثالية أ>ع؟ ۲٥م‏ 
accuracy)ولکن‏ مجاله أكثر تحديداً.يبين الجدول التالي هذه الأنواع الثلاث. 


System.Decimal‏ کاملة(ایمfم۲)‏ محدود يدعم تقريبا حوالي28 أرقام موحدة على كلا جانبي النقطة العشرية.ويمكن أن 

يحذف بعد هذا الموضع الرقم المتاح الأخير .فدقته ضمن هذه الأرقام.وبسبب 
هذاءفإنه مناسب للعمل مع العملة.كلما كانت الأرقام التي لديك أكثر على يسار 
الفاصلةءكلما قلت لديك الأرقام المتاحة على يمين الفاصلة العشريةءوالعكس 
بالعكس هوه هءزاءبالنسبة للأعداد التي ليس لديها جزء عشري يكون 
المجال t0‏ 79,228,162,514,264,337,593,543,950,335- 
(Thats 29 digits)‏ .79,228,162,514,264,337,593,543,950,335 

بالنسبة للأعداد الصفرية فقط(0) على يسار الفاصلة العشريةءالمجال يكون : 

-0.0000000000000000000000000001 to 


0.000000000000000000000000000 1 


البيانات وأنواعها. 


N 


System.Double‏ غد ضخم يشبه سابقه»ولكن بمجال أكبر .من أجل القيم السالبةءالمجال هو:من 
-1.79769313486231E +8‏ إڵى:324-4.94065645841247E-‏ 
ومن أجل القيم الموجبةءالمجال هو:من 
E-224‏ 494065645841247 إلى 1.79769313486232E+308:‏ 


يتضمن إطار العمل نوعين من البيانات المتعلقة بالنصوص. ١2٤.٣عاكركو‏ وnااm.StعtءSy.‏ نوع البيانات الحرفية ۸2۲٤يحفظ‏ حرف مفردءلا أقل 
ولا أكثر.ففي 16بت»يحفظ حرف من أي من آلاف حروف اليونيكود. 

ونوع بیانات السلاسل الحرفية 9 تسمح حتی حوالي 2بلیون حرق من حروف یونیکود وأن يتم صفها مع بعضها البعض في مقطع نصي 
طويل.السلاسل الحرفية في الدوت نت ثابتة(لايمكن تغيرها عاطةاuا" ١‏ |).فحالما تعمل على إنشاء سلسلة نصية ماءفلايمكن تغيرها بأي 
طريقة .ذا أردت ا نص إلى اله حرفية موجودة. فان الدوت نت سيعمل على إنشاء وسمة(علامة)سلسلة حرفية جديدة مبنية من 
علی الرس أن الحرفية والس لس اة الحرفية أنواع بيانات مختلفة» بإمكانك بسهولة نقل البيانات بينهماءبما أنهما معتمدان على حروف 


1 8 3 الأساسية. 


يسمح لك aiع‏ llبlilٽ System. DateTime‏ من تخزین إما قيم تاریخ أو وقت(أو كلاهما)كبيانات. داخلياً» إن ۳٥‏ ۲هو عبارة عن عداد عددي 

صحیح بسیط یعرض تنسیق تاریخ أو وقت محول عند الحاجة .وکعدد»فانه یحسب عدد "الدقات ء)عاا "منذ00 :12صباحاً .1 کانون الثاني 

ءسنة1بعد الميلاد(۸0 1 ,1 a.m. on January‏ 12:00).كل دقة”)ءا" هي تماما100نانوتانية.لذلك فهو دقيق جدآ.التاريخ الأعظمي المسموح به 
31 کار ن الأول 9999.في الت فويم اله ي(الکاتولیکي). 


يمثل نوع البيانات 2۸عا600."عاءرS‏ ماهيةعء"عءءe‏ بيانات الكمبيوتر الحقيقية:وهو البتاأط .فهو يحفظ واحد من قيمتين ممكنتين:صواب عuں٣‏ 
أو خطİ False‏ . 

من المجححف Shockingly‏ أن يستخدم نوع البيانات الذي يحتاج عملياً مابين 2 و4بايت(32بت)من مساحة(فراغ)بيانات لحفظ مسار بت مفرد من 
البيانات. مما أظهر أهمية القيم المنطقية في البرامج.وكمطور,فإنك دائماً تختبر شروط متنوعة لترى أي منها يتحقق قبل أن تعالج مقطع من 
کود. کل هذه الشروط تختصر 40۷7 ا60 أخيراً لقيم منطقية 2ع8001وعملیات5 opera] ٥ ٣‏ . حتى أن للدوت نت طرق لنقل البيانات بسهولة 
بين القيم العددية الصحيحة ونوع البيانات المنطقية.في مثل هذا التحويلات »ءيصبح الصفر(0)خطأً وتصبح باقي جميع القيم الممكنة صواب .وعند 
الانتقال من المنطقي إلى ما يكافئه من القيم العددية الصحيحة فإن خطأً يصبح(0) وصواب يصبح(-1).(إذا استخدمت لغة سي شارب 
#٤»ستجد‏ أنها تحول صواب إلى 1 وليس-1ءداخلياً في الدوت نت» يتم تحويل صواب إلى1ءولكن لأسباب تاريخية»تستخدم الفيجوال بيسك- 
1.وهذا الاختلاف عادة لشن بالمشكلة مالم تخزن القيم المنطقية كأعداد صحيحة في ملف على قرص ما وتتوقع من برامج فيجوال بيسك 
وسي شارب ٤#‏ أن تفسر "8۲۲٤٥٤‏ البیانات بشکل صحیح). 


لقد علمت مسبقاً أن الدوت نت بيئة تطوير كائنيه التوجه(موجهة بJlکlئi|ٽenviro¬ment development‏ oriented-ect‌زطە‏ )»کل شيء في 
الدوت نت- كل الكود وكل البيانات- يتم اشتقاقها (مستمدة)من فئة قاعدية واحدة: ا 6زط0.١٠ع55.بنفسها‏ هذه الفئة ليس لديها الكثير من 
الميزات.يمكن أن تخبرك عن اسمهاءنوعهاءوفيما إذا حالتين(نسختين) من كائن هما في الواقع كائن واحد ونفس الكائن.غير ذلك فهي ليست 
مفيدة للكثير ما عدا أنه يتم استخدامها كنقطة بداية بالنسبة لجميع الفئات والأنواع .لأن جميع الفئات في الدوت نت -ومن ضمنها كل أنواع 
البيانات- تستمد(تشتق)من ا٤٤[ط۳.0عا5/5.‏ تستطيع معاملة حالة من أي فئة(أو نوع بیانات) ككائن .وستتذكر البيانات ما هو النوع الحقيقي 
الذي هي عليهءلذلك إذا كان لديك ۸7.1132عک5Sy۷موضوع‏ ک ا٤ع[۳.05٣عSyst.‏ تستطیع تغیره إلى 1132.١5۷58۸فیما‏ بعد. 


| 


ارجع إلى الفصل الأولءلقد قرأت الاختلاف بين الأنواع ذات القيمة والأنواع المرجعية.فالأنواع ذات القيمة هي خانات(حاويات كأه)عاط ) تحتوي 
على البيانات الحقيقية» والأنواع المرجعية تحتوي تعليمات ك١‏ 0٥آاع‏ لاعن المكان الذي تستطيع إيجاد البيانات الحقيقية.بشكل عام تحتوي 
الأنواع ذات القيمة قيم بيانات صغيرة وبسيطة, بينما الأنواع المرجعية تشير إلى مقاطع بيانات معقدة وكبيرة.وهذا ليس دائما صحيح»ولكن من 
أجل أغلب البيانات التي تعمل معهاءفإنه سيكون صحيحا.إن أ#زط۳.0ع5/51 هو نوع مرجعي والذي منه يتم اشتقاق جميع الأنواع والفئات 
الأخرى .وهذا يتضمن جميع أنواع البيانات الأساسيةءلذلك ریما تفکر أنها جميعها أنواع مرجعية أيضاً. ولكکن يوجد فئة أخری معلقة بين 
System.Object‏ ومعظم أنواع بيانات الفيجوال بيسك.وهذه الفنة#م۲۷عuاة۷.‏ ٠8ا55‏ » . تنفذ التعريف الأساسي والاستخدام لنوع ما ذو 
قيمة.يبين الجدول التالى بعض الاختلافات بين الأنواع المرجعية وذات القيمة. 


1.تشتق في النهاية من عم۲۷ع۷21u.٣عاءل5.‏ والذي بدوره يشتق من †)€ز۸.05عSyst.‏ 

2 .أنواع البيانات الأساسية المشتقة: المنطقية1 2ع ا800 .البايتعا/8 .الحرفي۲ه"١C‏ .التاريخ والوقت۴ع ١‏ اه0 .العشري اة" |0 .المزدوج 
eا0ubط.القصير1"16‏ .الانتغر11132 .الطويل1164 .البايت بإشارةعا58۷ .المفردعاو١ا؟S‏ .القصير بدون إشارة1,۲16ل .الانتغر بدون إشارة 
2ال .الطویل بدون إشارة64, 1ل . 

3.توفر دعم لتراكيب الفيجوال بيسك ,St۲ ucu ۲e5‏ 

.System.Object << System.ValueType <<System.Enum:ylı leSEnumerations تٽlدlدعll‎ قlaتشl 4.يت۾م‎ 

5.لايمكن اشتقاق الأنواع ذات القيمة من فثات أخرى أو تراكيب ولا حتی یمکن للتراکیب ان تشتق منها. 

6.لايمكن وضع الحالات(النسخ)إلى "لاشيءو” 11اه "(استخدام النوع "قابل لأن يكون بدون قيمة عاطةاالام "يتفلب على هذا القصور 
(limitation‏ 

7.يمكن للحالات أن تحتوي فقط بيانات من نوع محدد.على سبيل المثال»نسخ(حالات) 1132.١٣5۷58يمكن‏ أن تحتوي فقط بيانات عددية 
صحيحة وع ا iباشارة‏ اأb-32.‏ 


3 البيانات وأنواعها. 


الفصل السادس:البيانات وأنواعها. Mhm76‏ 


8.التبدید بالکامل يتم بعملیات مج nllخdlخlٽcollectior .„.NET garbage‏ 


1.في النهاية ءتشتق من ٤٤ز‏ 0."عاSys.‏ 

2. أنواع البيانات الأساسية المشتقة:السلاسل الحرفية و١أ٣)؟.‏ 

3.توفر دعم لفئات الفيجوال بيıسك .Visual Basic "classes"‏ 

4.تستخدم التفاويض 5ع2وء !ع0 كمراجع(مؤشرات)لطرق الفنةكله٣أع"‏ ءءهاc‏ وتشتق كما يلي System. Delegate:‏ << 
“multicast delegate" ضيواختll عlgil ı>l.System.Object‏ " يتم اlشتlaقa ja‏ خSystem.MulticastDelegate:JlIl‏ . 

5.يمكن أن يتم اشتقاق الأنواع المرجحعية من فئات أخرى»ويمكن أن تستخدم كفئات قاعدية (يمكن أن يتم الاشتقاق منها أيضا) 

6.يمكن وضع الحالات(النسخ)إلى "لاشيء Nothing‏ " 

7.تشير عادة الحالات(النسخ) لبيانات النوع الذي عرفها(المعرفة منه).ولكن يمكن لحالة أن تشير أيضاً إلى النوع المشتق.على سبيل 
المثال»حالة من 9١۲1†؟5."عاكS۷‏ يمكن أن تشير لأي بيانات تستخدم 9١1١†5S."عاءرS‏ كفئة قاعدية ككهاء مكط. 

8.يتم تدميرها من خلال مجمع illخlڀlٽت .garbage collection‏ 

(بالإضافة للفئات والتراكيب» تعرف الفيجوال بيسك أيضاً "الوحدات البرمجية كعااكه" ".توثيق الدوت نت يحدد الوحدات البرمجية كعاuاكه"‏ على 
أنها أنواع مرجعية»ولكنك لاتستطيع إنشاء حالات(نسخءعع١‏ اكا )منها.) 

يمكن للأنواع ذات القيمة أن تحتوي فقط بيانات من نوعها الخاص »ولكن الأنواع المرحعية يمكن أن تشير إلى الحالات المشتقة.وهذا هام في 
الدوت نت»حيث أنه تم تصمیيمها لتسمح لحالة اءعزط0. ”عارك من الإشارة إلى أي بيانات في تطبیق ما.نسخ(حالات) زط ۳.0ع Syst‏ یمکن 
أن تشير إلى إما لبيانات لنوع ذو قيمة او لنوع مرجعي.هذا سهل الفهم بالنسبة للأنواع المرجعية بما أن تلك الحالة(النسخة)ستشير فقط 
لبعض الحالات المشتقة من نفسها.ولكن إذا أسندت نوع ذو قيمة إلى ٤عزط0.عاء5۷‏ المرجعي »فعلى الدوت نت أن يعلّم(يضع علامة 
)اaص)تلك‏ الحالة بطريقة خاصة ليشير إلى أن النوع المرحعي يحتوي نوع ذو قيمة. وهذه المعالجة(العملية) تدعى (الصندقة 20×٣9‏ )وعكس 
العملية يطلق عليه(.و0×7ظ7).على الرغم من أن الصندقة و”0×1طمفيدةءوفي بعض الأحيان أساسية.فإنها تأتي بأداء فعلي يزعج بشدة 
.substantial performance hit‏ 


جميع أنواع البيانات المنفذة في لغة الفيجوال بيسك هي أغلفة لأنواع بيانات الدوت نت الجوهرية.فقد تم تفيير فقط بعض الأسماء 
للمحافظة على البساطة. يبين الجدول أنواع بيانات الفيجوال بيسك وما يكافئها في الدوت نت . 


Visual Basic type .NET type 

Boolean System. Boolean 
Byte System. Byte 
Char System. Char 
Date System. DateTime 
Decimal System. Decimal 
Double System. Double 
Integer System. Int32 
Long System. Intb4 
Object System. Object 
SByte System. SByte 
Short System. Int16 
Single System. Single 
String System. String 
UInteger System. UInt32 
ULong System. UIntb4 
UShort System. UInt16 


كل أنواع بيانات الفيجوال بيسك قابلة للتبادل بالكامل مع ما يكافئها في الدوت نت.وأي حالة من ١.1۸132‏ هءركيمكن أن يتم معاملتها وكأنها حالة من إموهام|ءوالعكس 
بالعكس. 


4 البيانات وأنواعها. 
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الطريقة الأسرع في تضمين قيم لنوع بيانات معين في كود الفيجوال بيسك هي استخدام المحارف(الحرفية).ولقد رأيت سابقا في الفصل الأول من هذا الكتاب كيفية 
استخدام الحرفية في مثال المشروع وكما يلي: 

MsgBox("Hello, World!") 
هذا الاستدعاء لدالة ×80 وء/إيتضمن محارف السلسلة الحرفية.محارف السلسلة الحرفية تظهر دائما ضمن علامتي اقتباس مضاعفةوعاoںې eااںمل . ومعظم‎ 


المحارف العددية تظهر مع الحرف المعرف لنوع البيانات إعأعجإمnء‏ وfininمd-ممyرt-ataه‏ في نهاية المحرفاه٣6]ا‏ .ولكن يوجد تنوع آخرءيبين الجدول التالي 
قائمة بقيم المحارف المختلفة التي بإمكانك تضمينها في كودك. 


محارف حرفية مفردة تظهر ضمن علامتي اقتباس مضاعفة مع التذييل بالحرف ء.المحارف من 
النوع ۲م ليست نفس المحارف الحرفية المفردة من نوع السلاسل الحرفية ومنم؟. 


123.45D,123.45@‏ القيم ذات النقطة العائمة امم-وز†جه|۴من النوع العشري امعم صيتم إتباعها ب 2 »أو بالرمز.@. 


بإمكانك تضمين المحارف الست عشرية اع_اءمله×همفي كودك ببدء القيمة بالتعاقب الحرفي”&“ 
»متبو عة بالأرقام الست عشريةوانوال ×ط . 


&HABCD Hexadecimal 


قیم عددية صحيحة من النوع الطویلوہها »ءتكون متبو عة بالحرف الكبير 1 »أو بالرمز. ي٠‏ أيضاءإذا استخدمت 
محارف عددية تقع ضم مجال الوه ]ا »ولكن دون تذييل حرف يبين نوع البيانات»فإن ذلك المحرف سيتم إعطاءه 
النوع من نوع بیانات‌وہ‌ها . 


123.458&123.45L Long 


.8 القيم الصحيحة من النوع القصير 0۲ Sتكون متبوعة بالحرف الكبير‎ 123.458 Short 


LSE 24 JI EEE GEITETSE TEES ETT CET EET EYEE 
۳ علامة اقتباس مفردة‎ 


"A '"B" a String 


المحارف جيدة»ولكن ليست دائما واضحة بما تعنیه.توفر الثوابت طريقة لإسناد أسماء ذات معنی للقيم الحرفية(المحارف)ءويتم معاملتها تماما کالقیم 
الحرفية(المحارف)ءولكن ذات تعریف وحید»یمکن أن يتم استخدامها مرة بعد مرة في كودك.وكل استخدام لقيمة حرفيةءحتى ولو كان لديها نفس القيمةءفهي تمثل 
تعريف جلي وحالة من القيمة.في الفيجوال بيسك يتم تعريف الثوابت باستخدام الكلمة المحجوزة ئمه٥.‏ 

Const MonthslnYear As Short = 12‏ 
تعريف التابت لديه الأجزاء التالية: 


في هذه الحالة اسم الٹابت هي:Months|nYear‏ 


يعرف هذا المثال ثابت من النوع القصيراهم5 . نوع البيانات دائما تأتي بعد الكلمة المحجوزة ئ۸. 

إذا لم تضع الكلمة المحجوزة ء4ءفإن نوع بيانات الثابت ستكون من نوع المحارف التي تم إسنادها له.وأنواع البيانات التالية فقط يمكن أن يتم استخدامها من أجل 
الثو ابت: المنطقية هم امم ءالبايت هارع ءالحرفي۲همع ءالتاريخ هو ٬العشر‏ ي اهاعم ءالمز دو جم ااه ءالعددي الصحيحمومام| الطويلومم] ءالكائن 
bjet‏ »البايت بإشار ةه ر68 .القصير هم5 المفر دم اواك السلسلة النصيةوم ا)5 ءالعددي الصحيح بدون إشارةموهم ال ٬الطويل‏ بدون إشارةومه ال ٬القصیير‏ 
بدون إشارةort JS‏ «İو‏ اسم عاد enumeration‏ . 


الممهد المسند هنا هو 12.حالما يتم إسنادهاءفإن هذه القيمة لايمكن أن يتم تعديلها بينما يكون كودك في وضع التشغيل.والثوابت دائما أنواع ذات قيمةءوليست من النوع 
المرجعي.والممهدات عادة تكون محارف بسيطة»ءولكن بإمكانك دائما تضمين حسابات بسيطة: 
Const Seven As Integer = 3 + 4‏ 


يمتل تعريف الثابت تنسيق مثالي ٠۷٠۵۲‏ امه لتعريف ثابت مضمن ضمن كود إجراء.بإمكانك أيضا تعريف ثوابت خارج إطار الإجراءات»ولكن يبقى ضمن فئة 
او نوع أخر. عندما تعمل هذا»عادة تعمل غلی إضافة الكلمة المحجوزة لأمحدد الوصول access modifier‏ تماما قبل الكلمة المحجوزة Const.وهذo‏ الكلمة المحجوزة 
تشير إلى الكيفية التي بها سیستخدم معظم الكود هذا الثابت.وساشرح محددات الوصول 00/۴/۲ sئ٥عءء‏ ص فيما بعد»ولكن الثوابت المعرفة ضمن إجراء يمكن 
استخدامها فقط ضمن ذلك الإجراء .حالما تعرف ثابت»ءبإمكانك استخدامه في أي مكان تود استخدام ما يكافئه من المحارف. 

Const GreatGreeting As String = "Hello, World!" 


...Later... 
MsgBox(GreatGreeting) 


البيانات وأنواعها. 
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لعدادات واحدة من أنواع الدوت نت الجوهريةءتتيح لك تجميع مسميات»وقيم عددية صحيحة متعلقة بهذه المسميات كمجموعة.حالما تريطهما 
ببعضهما» یمکن للعداد ان يتم استخدامه مٿثل اي نوع بيانات أخر بإمكانك إنشاء متفيرات بحيث تكون حالات خاصة من عداد. 
العدادات هي تشييد متعدد الأسطرءيعرف السطر الأول الاسم ونوع البيانات الملقاة تحت العداد. كل عضو عداد يظهر في سطر منفصل»يتم 
الإنهاء بسطر E۸۵ ۴٣۱1۳‏ الذي في النهاية يغلق العداد. 
Enum CarType As Integer‏ 
Sedan = 1‏ 
StationWagon = 2‏ 
Truck = 3‏ 
SUV = 4‏ 
Other = 5‏ 
End Enum‏ 
يتضمن السطر الأول التصريح عن العداد بالكلمة المحجوزة 5١1۳‏ واسم العداد(عم3۲۲۷٤)»ءونوع‏ البيانات المضمن(9€6۲عا11).والتعبیر ك ك۸ لنوع 
البيانات هو اختياري.فإذا لم تضعه»فإن النوع الافتراضي للعداد هو العدد الصحيح9€۲ع1"1 .فإذا زودت بنوع البيانات»فيجب أن يكون واحد من 
الأنواع التالية: البايتعار8 .العددي الصحيح۲ع9ع|ا"1 .الطويل ٠١9‏ 1ءالبايت بإشارةع†ر58 .القصيرا0۲ 5 .العددي الصحيح بدون إشارة 
.1nteger‏ الطویل بدون إشارةو٣٥‏ الا »أو القصير بدون إشارة 0۲ 5لا. 
کل عضو من العداد(السطر من 2إلى 6)يجب أن يتضمن على الأقل اسم عضور(مثل ١58۵3).بإمكانك‏ بشكل اختياري إسناد قيمة عددية لبعض 
أو لجميع الأعضاءء كما فعلنا بالمتال.فإذا ما نقص عضو إسناد ماءفيتم وضعه بزيادة واحد عن العضو السابق.أما إذا لم يتم إسناد أي عضو 
لقيمة»فيتم إسناد الأول ل0ء والتالي 1»وهكذا .حالما يتم التعريف» تتصرف أعضاء العداد بكثير من الشبه للثوابت العددية الصحيحة»يإمكانك 
استخدامها في أي مكان تريد استخدام عادة الثوابت أو المحارف.عندما تشير لأعضاء عداد في كودك»ضمن كلا من اسم العداد واسم العضو. 
CarType.Sedan‏ 
العبارة ۷۳ ۴لايمكن استخدامها ضمن طريقة e۸٥4‏ أو إجراءeاduععهام‏ .بدلاً من ذلكءإنك تعرف عداد كعضو من نوع(فئة 55ا تركب 
۲ .أو وحدة برمجية عااكه")ء أو كنوع خاص قائم بذاته» تماما مثل الفئة.يتضمن إطار عمل الدوت نت العديد من العدادات المفيدة 
فة مسبقاً معدة لعل١‏ عا”¡ للاستخدام مع ميزات كعإںاةء؟ إطار العمل .على سبيل المثال.العداد )عع۷0Wهm.0عاtكرك‏ يتضمن أعضاء 


ل5 أيام الأسبوع. 


المحارف مفيدة وجيدة»والتثوابت والعدادات أفضل» ولكن ولا واحد منهم يمكن أن یتم تبدیله حالما يبدأ البرنامج.وهذا مايميل لجعل تطبيقك جامد 
وغير مرن. المتغيرات هي حاويات مسماة من أجل البيانات»مثل الثوابت تماما »ولكن. يمكن أن يتم تعديل محتوياتها أثناء تشغيل 
التطبيق.وأيضاًءيمكن أن تحتوي على أنواع ذات قيمة وأنواع مرجعية.إليك التركيب الأساسي لتعريف متغير جديد: 

Dim customerName As String 
الكلمة المحجوزة | ا5 أصلاً من الكلمة 0/78۸50 -تعرف متغير جديد»في هذه الحالةءسمي المتغير ٥۳١۲ع" 0اكلاعمع نوع البيانات من نوع‎ 
»أو متفيرات نصية أخرى‎ string literalsãصi السلسلة الحرفية 4 .هذه الحاوية المسماة جاهزة لحفظ أي قيمة نصية» أسند له محارف‎ 
قيم معادة من دالات ك١٥آاء”ناfتولد سلاسل حرفية95 ”٣ء .وبما أنه من النوع المرجعيء»فيمكن أن يتم وضعه أيضاً إلى‎ وأ.strinو‎ variabاes‎ 
"لاشيء 9١اه "(قيمة خاصة بالفيجوال بيسك وهي كلمة محجوزة تعني"هذا النوع المرجعي فارغ»فارغ بكل معنى الكلمة")‎ 


eus Eomer Name > MocRInO | Nothin, EN 
EUS OMe Name > e O Eel aS 
EUSEOMEE EME E GSE EME ODE NANE SE ل ع‎ 5 
والأنواع القابلة بدون قيمة‎ 1 rwe تحتوي قيمتها الافتراضية حتى تضع لها شيء ما آ‎ 
»القيمة الافتراضية هي"لاشيء ©8518[ ".أما من أجل الافتراضي هو 0 .المنطقية الافتراضي هو خطاأً‎ 


»بإمكانك تضمين إسناد أولي كجزء من عبارة "01 لإعادة قيادة عل١0۷6۲۲الإسناد‏ الافتراضي. 
Dim COuUntEdoWnSecoOndSs AS SRORE G0‏ 
Dim processingDate As Date = Today‏ 
Dim customerName As String = GetCustomerName (customerID)‏ 
السطر الأخير يبين نوع مرجعي-سلسلة حرفية-تم إسناد لها نتيجة سلسلة حرفية لدالة .يإمكانك أيضاً إسناد حالة موسومة ب ٠6۷‏ لحالة 
مرجعية إلى متغير من النوع المرجعي .وبالتالي فهو جديد»فهو يستخدم الكلمة المحجوزة الخاصة 6W'.ءوالتي‏ تقول"إني أعمل على إنشاء 
حالة جديدة من نوع بيانات خاص." يوجد العديد من التنوعات المختلفة ولكن كلها تعطي نفس النتيجة. 
One-line variation.‏ ا 
Dim someEmployee As New Employee‏ 
AnoEner enez line variation,‏ 0 
Dim someEmployee As Employee = New Employee‏ 
woz inme vara E HOM.‏ جد ١‏ 
Dim someEmployee As Employee‏ 
eT = New Employee‏ 
تذكر أن الأنواع المرجعية هي معلبات كأع)عناطتحتوي على أدلة eti‏ dirلموقع‏ البيانات الحقيقي»فعندما ينبثق متغير مرجعي للوجو 
وللمرة الأولى .فانه يحتوي على لاشيء9٣‏ 11اه . وهذا كل شي»ءءفالمعلبة )طلا تحتوي تعلیمات 5٣٥ا‏ ںایم على الإطلاق بما ا ا 
يوجد بيانات مرتبطة مخزنة في أي مكان.وعندما تسند حالة جديدة ٥٥١ةاك١¡ "6۷W‏ لمتغير من النوع المرجعي»فإن تلك الحالة يتم تخزينها في 
مكان ما في الذاكرةر۲ام۳ع" . وتعليمات عن موقع تلك البيانات يتم إفراغها ١عم"لالضمن‏ المعلبة.في مقطع الكود السابق»كل استخدام 
للكلمة المحجوزة 6#[أيعمل على إنشاء حالة(نسخة])بيانات جديدة في مكان ما في الذاكرة.وموقع هذه البيانات يتم إسناده فيما بعد إلى 
المتغير .S٥m ع٤٣ p۱٥۷€€‏ 
تتضمن العديد من الفئات واحد أو أكثر من المشيدات ء/مغعراورهء .الإجراءات الممهدة كع u†iها‏ izationاitiaمi‏ التي تثبت القيم الأولية اها اہ 
ئاق لحالة.بإمكانك استدعاء مشيد خاص من خلال العبارة ۸6۷.يتضمن نوع بيانات السلسلة النصية 9٣١۲ء‏ مشيدات ك0۲ا٣‏ ٣ئ١0‏ تتيح لك 
بناء سلسلة نصية أولية.واحد من هذه المشيدات الخاصة يتيح لك إنشاء نص يحتوي على عدة نسخ من حروف خاصة.العبارة التالية تعمل 
على إسناد سلسلة حرفية من 25نجمة للمتغير 53۲5 0]50|. 
DEM LOESOESEAES AS NEW SEENON e 25) 1‏ 
سيتم مناقشة المشيدات بالتفصيل في الفصل 8 إن شاء اللّه. 
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يمكن لعبارة 0i"‏ أن تظهر في أي مكان ضمن إجراءء ولكن بالنسبة للتقليد فإنها تظهر تماماً عند بداية الإجراءءقبل أي عبارة منطقية أخرى 
Sub MyProcedure ()‏ 


End Sub 
كما مع الثوابت»يمكن أن يتم تعريف المتغيرات إما ضمن إجراء أو خارج إجراء ولكن ضمن نوع ما.(المتغيرات والثوابت المصرح عنها خارج إجراء‎ 
/ه٤cةقا تعرف بالحقولءك/ .والمتغيرات والثوابت المصرح عنها ضمن إجراء تعرف أيضاً بالمتغيرات المحلية كع/اطةا/ا /aء٤0/ والثوابت المحلية‎ 
على الترتيب.)يتم استبدال الكلمة المحجوزة "01۳ بواسطة واحد من محددات الوصول ء/ع/700/ ئئع٤٤ 2 فيما يخص الحقول‎ .onكاtاهnاtك‎ 
:fields 


المتفيرات الخاصة كعاطةأ۲ة۷ عاة۷أ۴۲ يمكن أن يتم استخدامها بواسطة أي عضو أو إحراء ضمن النوع» ولكن ليس في أي مكان أخر.إذا عملت 
على اشتقاق فئة جديدة ككةاء ۸6۷ من فئة قاعدية ككةاء عة والتي تتضمن متغير لنوع خاصعأة۷آ۲م »فإن الكود في تلك الفئة المشتقة لن 
ن له إمكانية الوصول على الإطلاق إلى ذلك المتغير الخاص »حتى أنه لن يعلم أبداً أنه موجود. 


المتغيرات الصديقة هي خاصة بمجمع ماراا”#ءءة .يمكن أن يتم استخدامها بواسطة أي كود في النوع المرتبطة به.ولكن أيضاً بواسطة أي 
كود في أي مكان في نفس المجمع.حالياً هذه هي المتفيرات الصديقة. 


المتغيرات العامة تكون متاحة في أي مكان.فهي ممكنة لكتابة تطبيق ما أو مكون بعرض أنواعه لكود أبعد من نفسه.وأي شيء يتم تعليمه 
كعام يمكن أن يتم عرضه في هذه الطريقة. 


المتغيرات المحمية تشابه كثيراً المتغيرات الخاصة»ولكن الكود في الفثات المشتقة يمكن أيضاً أن تصل إليها.بإمكانك استخدام الكلمة المحجوزة 
Protected‏ 
فقط فى تعريف الفئة5ءه‌اz‏ » فلن ز في التراكيب ۲۴ا٤‏ ۲۷ءوالوحدات البرمجيةعاuله"‏ . 


تجمع المتغيرات الصديقة والمحمية كل ميزات الصديق والمحمي.يمكن أن يتم استخدامها فقط في الفئات. 
يمكن لفئة مفردة أو نوع أن يحتوي على الحقول كلاعاfوالمتغيرات‏ المحلية كعاطةا ۷2 اها والثوابت „constants‏ 
Class melass‏ 


1 > Here's a field. 
Private InternalUseOnly As Boolean 
Sub MyProcedure () 
صد ا‎ Here's a local variable. 
Dim myVariable As Integer 
Ema SUS 
ERG Class 


توجد تنوعات تركيبية أخرى لعبارة "0۳ء بعض منها سأناقشه فيما بعد في هذا الفصل والفصول الأخرى. 


عندما تعرق متغیر ضمن إجراء۲e‏ ٤٤٥۲م‏ .فان له مدی علي مستوى الإجراء 0ءء 0/0٥٥2 e-/€۷€/‏ .وهذا يعني أنك تستطیع استخدام 
المتفير في أي مکان ضمن الإجراء. سيكون لإجرائك على الأرحح "عبارات مقطعيةءا stat eme‏ )ocاb‏ "وهذە العبارات»مٿل For...Nexو‏ 
۴...١‏ والتي تتطلب أكثر من سطر وحيد من الكود المصدري لاكتمالها. إذا أضفت عبارة "0iبين‏ سطري بداية ونهاية واحد من هذه 
العبارات.فإن ذلك المتفير المصرح عنه سيكون لديه فقط مدى على مستو المقطععمهءء /أعم٠ع/-۸‏ 0/0 .وسيكون متاح فقط ضمن ذلك المقطع 
من الإجراء. 
EOE COoUnNEer > 1 To 10‏ 
Dim processResult As Integer‏ 
More code here.‏ ج ا ا 
MEE COLES E‏ 
هذا االشسطر من المكروة MSsGBOxX (pEOSeSSKe SUE) _ 1 ain‏ 
يصرح هذا الكود عن ااcessResuهءpضمن‏ مقطع ا×۸6...١۴١۴.لذلك.‏ فهو متاح فقط للاستخدام داخل ذلك المقطعء وأي محاولة لاستخدام خارج 
إطار مقطع ۲٥۴فسينتج‏ عنه خطأً مباشر €0 immediate‏ . 
إن عمر ۳٥‏ /ع///المتغیر على مستوى الإجرlاء level variable‏ -edureع0ام‏ يبدأ عندما يدخل الكود للمرة الأولى ذلك الإجراءءوينتهي عندما يخرج 
الكود الإجراء. وهذا صحيح بالنسبة لكل من المتفيرات على مستوى المقطع وأيضاً على مستوى الإجراء.وهذا يعني أنك إذا أسندت لمتغير 
على مستوى مقطع قيمة ما قبل أن يوجد المقطع. فإنه(المتفير)سيبقى لديه تلك القيمة إذا ما عدت ودخلت ذلك المقطع خلال الاستدعاء 
لنفس الإجراء. 
بالنسبة للحقول كلاعاf(المتفيرات‏ على مستوى الفئةكعاطة۲ة۷ ام۷عا-كءهاء ).يعتمد المدى عم٥0ءءعلى‏ مستوى الوصول المستخدم عند 
التصريح عن المتغير.وعمر الحقل يبدأ عندما يتم إنشاء نسخة(حالة) من الفئة في الكود.وينتهي عندما يتم تدمير الحالة آو تخرج تماما من 


الاستخدا 


لا تعليق. 


يتضمن الفيجوال بيسك تشكيلة من المعاملات التي تتيح لك معالجة قيم متفيراتك.لقد رأيت سابقاً assignment operator|iwۈلl Jal‏ 


(=)ءوالذي يتيح لك إسناد قيمة مباشرة لمتغير. معظم المعاملات الأخرى تتيح لك بناء تعابير تضم عدة قيم أصلية بطرق منهجية(قانونية) 
للإسناد النهائي لمتفغير.خذ العبارة التالية: 


البيانات وأنواعها. 


J 


squareArea = length * width 
تتضمن هذه العبارة معاملين:الإسناد ١٣ع" ١9واكهوالضرب ١10هام ااص.معامل الضرب يوحد قيمتين(الطول والعرض)باستخدام الضرب.ومعامل‎ 
الإسناد يخزن الناتج في المتغير 3١١413۲8۸ء.بدون المعاملات» ستكون تحت ضغط كبير لحساب المساحة ه۲۴ةأو أية صيفة أخرى قد تكون‎ 
. complex formulaةدقعمe‎ 
يوجد نوعین من المعاملات غير الإسنادية كإ0أaاممo nmentوassi-0nم :أحادي ,/ة” ۷و ثنائير/72/ :معاملات الأحادية تعمل فقط مع قيمة‎ 
نمضتت0pم€۲2١كك وحيدة»او مع عاملكلك١ة۲عم0 . معاملات الثنائية تتطلب عاملين»ولكن النتيجة في معالجة وحيدة. العوامل‎ 
.يبين الجدول التالي معاملات‎ function اreاu‎ ۲١ ۷جاuعكةداعمل المحارف(المحرفية كاةاع|ااا ).التوابتكا”هائممc .المتغيراتءعاطهةااج۷ .وقيم الدالة‎ 

تفا الاستخدام. 


(الإضافةماالهA‏ ).يعمل على إضافة عاملين مع بعضهماءلإنتاج مجمو ع ںء .بعض المبرمجين يستخدم هذا المعامل لإتمام 
توحيد سلسلة حرفية nمناة١ماهءهء‏ و ذع†ءءولكن من الأفضل ضم السلاسل الحرفية باستخدام معامل أخر(« )و المصمم خصيصا 
لذلك الهدف. التر كیب:عامل1 21ء م +عامل2 4۵2/٥م‏ .مثال:3+2 


الطرح .يطرح عامل(الثاني)من أخر(الأول)ويعود بالفرق. اتر کیب: ۲۵۵2م - ۸۵1 2ء٥م.مثال:4-10.‏ 


الضرب يضرب عاملین مع بعضهما»ويعود بالناتج التركيب: operand1 * operand2‏ مثال:3 82 


القسمة الصحيحة”م اواك هومم! .تقسم عامل (الأول) على عامل أخر(الثاني)وتعود بحاصل القسمةءأولا وہ ناهم ںم) تحذف أي 
Cl O N‏ 
المعامل /).التركيب: 202م | 01م er2مە.مثال:4‏ |9 . 


الأس(القوةم 0اه نامممم»ع ).يرفع عامل (الأول) إلى قوة الأخر(الثاني).التركيب: 202ء٠‏ مه ^ 241ممه.مثال: 2^8. 


عملية "و "»حرف العطف.” هنام دزم ه٥.ينجز‏ توصيل(جمع) منطقي أو ضم بتات موا« اطعلى عاملين»ويرجع النتيجة.من أجل 
العمليات المنطقية(البولين ههام ه8 ) ستكون النتيجة صواب فقط إذا ما قيّم معاملين لصواب.من أجل العمليات البتات(العددية 

الصحيحة)»كل بت(وحدة)اط )خاص في النتيجة سيتم وضعها إلى 1 فقط إذا كان البتين(الوحدتين)المتطابقين في كلا معاملين هما 
واحد1.الترکیب: And operand2‏ erand1مo‏ .مثال: .isOfficer And isGentleman‏ 


توحید قاصر llد|ر Short circuited conjunction‏ .هذا المعامل مکافئ ¿ للنسخة المنطقية من المعامل لوم۸»ولكن إذا تم تہ ته تقیم معامل الأول 
ا خطأءفان معامل الثاني لن یتم تقیمه عا الإطلاق.وهذا المعامل لايدعم عملیات البتات bit wis‏ ۳ 
التر کیب:۸02 ۲مہ isOfficer AndAlso isGentleman :JlÃn. operand1 AndAlso‏ : 


النفي هاه وه .ينجز نفي منطقي أو بتات على عامل مفرد.من أجل العمليات المنطقية(البولين)ستكون النتيجة صواب إذا تم تقييم معامل 
الت خطأءوخطاً إِذا ما تم تقیم معامل إلى صح .ومن أجل عملیات البت(العددية الصحيحة)»كل بت خاص في النتيجة سيتم وضعه ا 
إذا ما كان بت معامل المطابق هو 0»ويتم وضعه إلى 0إذا ماکان بت معامل هو 1. 

.Not readyToSend .مثال:‎ N operand1 التركيب:‎ 


الرفع اليساري)؟ه! ۴ا5۸ .المعامل رفع يساري 6۴۲ا ۴ا5 يرفع البتات للعامل الأول إلى اليسار بعدد المواضع المخصصة في معامل 
الثاني»ويعود بنتيجة. البتات المسحوبة للنهاية اليسرى للنتيجة يتم فقدانهااوه! ءالبتات المضافة إلى النهاية اليمنى هي دائما 0.وهذا المعامل 
يعمل بشكل أفضل إذا كان معامل الأول قيمة عددية صحيحة بدون إشارة. 

.&H25 << 3 :لاثم.ەpمeran1‎ << operand2 التركيب:‎ 


الفصل السادس:البيانات وأنواعها. Mhm76‏ 


= المساواةواواوم (المقارنة.("0ءriةمصهت).يقارن‏ عاملین ويعود صواب إذا کانا متساویان ی القيمة. 
التركيب: expectedAmount = actualAmount :لاثم.operand1 = operand2‏ 


أقل من مه وها .يقارن عاملين ويعود بصواب إذا كان معامل الأول أقل في القيمة من الثاني. عند مقارنة قيم لسلسلة حرفيةءفالراجع 
يكون صواب إذا ظهر معامل الأول أولا عند ترتيب سلسلتين حرفيتين. 
التركيب: raiseRate < inflationRate :لاثم.operand1 < operand2‏ 


أقل من أو يساوي ٥ا‏ اوه ۲ه ٤۸۵‏ 5ه 1.يقارن عاملين ويعود بصواب إذا كان الأول أقل أو يساوي بالقيمة معامل الثاني 
التركيب: .raiseRate <= inflationRate :لاثم.ەpمerand1 <= operand2‏ 


نموذج(عينة) مقارنہمءااةمصهء اهم .يقارن عامل أول إلى نموذج مخصص في الطرف(عامل) الثاني»ويعود بصواب إذا 

كان هناك تطابق.يدعم طرف(عامل)العينة(النموذجمءه)جم )بعض كروت التعريف ١٥لاس‏ (المحددة القيمة مسبةا)القاعدية وخيارات 
مختارة»وتم شرحها كاملا في المستندات المزودة بالفيجوال أستوديو.يتضمن الدوت نت ميزة تدعى التعابير النظامية 

.ءمانان٠n التي توفر الكثير وأعظم النماذج الشاملة مطابقة(ملائمة) الحل‎ وrهوuاar‎ expressions 

governmentlD Like ssnPattern :لاتم.operan1‎ Like operand2 التركيب:‎ 


مقارن نفي النو ع ”ممصت ممرا كم†مومN‏ .وهذا المعامل يقطع(يقصر )دارة استخدام المعاملين واو اهمع بعضهما. التعبيران 
Not (first Is second) :« first IsNot second :نlًlكتn jll‏ 
التركيب: something IsNot somethingElse :لاثم.operand1 IsNot operand2‏ 


ا 
. 


استعادة التفويض|ه ۷ء٣6 Delegate‏ .يعود بتفویض(مشروح د الفصل الثامن)والتي تمثل حالة خاصة من طريقة اجراء. 
التركيب: AddressOf one.SomeMethod :Jla. : AddressOf method1‏ 


تستخدم المعاملات غير الإسنادية Non-assignment oper 20s‏ عاملاتھا erandsمoللحصول‏ على نتيجة»ولکن لا تسبب تبدیل عوامل نفسها بأي 
طريقة.معامل الإسناد يعمل على تحديث العامل الذي يظهر في جهته اليسارية .بالإضافة إلى عامل الإسناد القياسي ءتتضمن الفيجوال بيسك عدة معاملات تجمع(تضم) 
معامل الإسناد مع بعض المعاملات الثنائية 


ane 


معامل الإسناد القياسي. 


1 


( subtraction -)¦|ر‎ 


a 
Il 


(division Anıق)/‎ 


> 


^ (القو الأس) (exponentiation‏ 


>>(الرة 


<<= 


shift left 


معاملات الإسناد هذه هي مجرد اختصارات للمعاملات المجسدة الكاملة.على سبيل المثال»لإضافة 1إلى متفير رقمي»بإمكانك استخدام واحد 
من هاتين الطريقتين: 
د کے ھا 0 a E‏ ا 
HOES SRAE  EOlCALSORAE FF‏ 
ا E EOEaN SORA E E‏ 
OEE SORE — I‏ 


عادة ينتهھهي عمر المتغير على مستوی الإجراء المحلي عندما ينتهي الإجراء .ولكن في بعض الأحيان ومن المحتمل أنك ترید من متغير أن یحفظ 
قيمته بين كل استدعاء ضمن الإجراء.ويعض الأحيان أيضاً ممكن أن تحتاج إلى مليون دولار ولكن لاتستطيع الحصول عليها دائماً.ولكن بإمكانك 
الحصول على متغيرات تحفظ قيمها إذا أردت.وهي تدعى المتغيرات الستاتيكية.للتصريح عن متغير ستاتيكيك/طة١/۷2‏ ا2ء »استخدم الكلمة 
المحجوزة ءاأةاك5في مكان الكلمة المحجوزة "01. 

Static keepingTrack As Integer = 0 


°) 


البيانات وأنواعها. 


الفصل السادس:البيانات وأنواعها. Mhm76‏ 


إن إسناد المتغير إلى صفر يتم عمله مرة واحدة فقط.وعندما تعمل على إنشاء حالة(نسخة) من نوع يحتوي على هذه العبارة.فيما بعد.فإنه 
يحفظ القيمة التي تم إسناده له من قبل مهما تكن حتى يتم تدمير الحالة(النسخة).يمكن أن يتم إنشاء المتفيرات الستاتيكية فقط ضمن 
الإحراءات. 


تعمل التطبيقات البرمجية غالبا مع مجموعات من البيانات المترابطة»وليس فقط مع قيم البيانات المعزولة.تتضمن الفيجوال بيسك طريقتين 
رئيسيتين للعمل مع مثل هذه المجموعات من البيانات:التجمعاتء١0)هاامء‏ (سنناقشها فيما بعد) والمصفوفات ك۷ه۲۴ه.تعمل المصفوفة على 
إسناد مواقع عددية إلى کل بند مضمن(محتوى) في المجموعة.تبداً ب0 وتنتهي بأقل1 من عدد البنود المضمنة(المحتواة).فمصفوفة من خمس 
بنود لديا عناصر مرقمة من 0 إلى 4 .وکمتال »تصور أنك تبرمح تطبيق يحاکي حديقة حیوانات.یمکن أن تضمن مصفوفة مسماة الحيوانات 
ةا" هوالتي تتضمن اسم كل حيوان في حديقتك: 
. حیوان 0#:آکل Aardvark Jail‏ 
. حيوان 1#: القرودہ00طھ8 
. حيوان2#:الشمبانز ي Chim p2^ ze‏ 
. حيوان l|;3#ھمlر Donkey‏ 
. وهلم وجر . : 
تعرف الفيجوال بيسك عناصر المصفوفة كأ٣ع"٣ءاع‏ ۲۲اه بالعدد الموضوع ضمن اقواس "u "b€‏ dعesizمarenthم‏ بعد اسم المصفوفة. فمن اجل 
حيواناتناء يعمل إسناد بسيط على وضع اسم نصي لكل حيوان في عنصر المصفوفة. 
animal(0) = "Aardvark"‏ 
animal(1) = "Baboon"‏ 
animal(2) = "Chimpanzee"‏ 
animal(3) = "Donkey"‏ 


استخدام كل عنصر مصفوفة سھل جدا: 
MsgBox ("The FIESE animal 16: € € GNM (OJ)‏ 


فكل عنصر من المصفوفة لايختلف كثيرآً عن المتغير القائم بذاته.في الحقيقةءبإمكانك فقط اعتبار مجموعة من الحيوانات في كود المثال لأن 
تكون متغيرات واضحة:متغير مسمى(۳31)0 371 .والآخر مسمى (1)ا۸1۳2ه» وهكذا.ولكن هي أفضل من المتفيرات العادية لأنك تستطيع 
معالجتهم جميعاً كمجموعة.على سبيل المثال»تستطيع تفحص كل عنصر باستخدام الحلقة ...۴ ۳.خذ مصفوفة عددية صحيحة مسماة 
"كل بند "18٤2ء‏ ":مع عناصر مرقمة من 0إلى 2. يضيف مقطع الكود التالي البنود المستقلة للمصفوفة وكأنهم متغيرات مختلفة . 
Dim totalAmount As Integer‏ 
totalAmount = eachlItem (0) + eachItem (1) + eachlItem (2) 1‏ 
ولكن بما أن البنود في مصفوفة عددية»تستطيع استخدام الحلقة ۴0۲...١6×‏ لعمل مسح لكل العناصرءبالدور(واحد واحد) 
Dim totalAmount As Integer = 0‏ 
For counter As Integer = 0 To 2‏ 
Keep a running total of the items.‏ > ج ا 
totalAmount += eachlItem (counter)‏ 
Next counter‏ 


قبل أن تسند قيم إلى عناصر المصفوفة»أو استخلاص هذه العناصر»عليك التصريح وتحجيم المصفوفة التي تريد.تعمل عبارة "على إنشاء 
مصفوفة كما تعمل مع المتغيرات العادية»والعبارة "۸€01۳تعمل إعادة تحجيم المصفوفة بعد ان تكون موجودة بقاً. 
Dim animal (0 To 25) As String ' 26-element array‏ 
Dim moreAnimals() As String ' An undefined String array‏ 
ReDim moreAnimals(O0 To 25) ' Now it has elements‏ 


عادة »ستعمل العبارة ١01٤۸على‏ مسح هط »أي بيانات موجودة ومخزنة في كل عنصر لمصفوفة.إضافة الكلمة المحجوزة ٥ع۲۷٥5ع٣۴تعمل‏ 
على صيانة ك٣‏ أهاع۲جميع البيانات. 
ReDim Preserve moreAnimals (0 To 30) ' Keeps elements 0 to 25‏ 
كل عنصر في المصفوفة كائن مستقل والذي يمكن أن يتم إسناد بيانات له عند الحاجة.في هذا المثال» كل عنصر هو سلسلة حرفية 
String‏ »ولکن تستطيع استخدام نوع ذو قيمة أو نوع مرجعي ترغب به في التصريح عن المصفوفة .إذا أنشغت مصفوفة من عناصر كائنية»بإمكانك 
دمج ومطابقة البيانات في المصفوفة»فالعنصر 0لايحتاج أن يحتوي نوع بيانات كما هو الحال في العنصر1. 
المصفوفة نفسها هي أيضاً كائن مستقل-حالة(نسخة) فة والتي تدير مجموعتها من العناصر المحتواة.إذا أردت تخصيص كامل 
المصفوفة »ولیس فقط واحد من عناصرها(وکان هناك وقت عند الحاجة لعمل هذا)»استخدم اسمها دون آي قوس او قيم موضوعة بترتیب 
تبك). 


تدعم مصفوفات الفیجوال بیسك أکثر من بعد واحدہ ٥٣€ 2/77٥5٥‏ (أو "رتبة ٣۵٣k‏ ").تشیر الأبعاد imensionsلإلى‏ عدد المجالات المستقلة 
المدعومة بالمصفوفة. فمصفوفة وحيدة البعد۷ة١۲ة‏ اة٣i0ئرع"ال-ع”ه‏ »مثل مصفوفة الحيوان اة٣٠أ"ةالمذكورة‏ سابقاءتتضمن مجال وحيد.أما 
المصفوفة ذات بعدين تتضمن مجالين مفصولين بفغاصلةكع9 ه۲2 dع†iصimامd-aصmصmمدc‏ »تشكل شبكة منظمة من العناصر»مع مجالات مفصولة من 


أجل الصفوف والأعمدة. 
Dain ELGCESCLSSBOAEIO TO OTO 2 79 AS CAE 1 9 < 9 OAS‏ 
ع أن يكون لمصفوفة حتى 60 بعد مختلف»على الرغم من أنه توجحد طرق أفضل لتنظيم البيانات من تقسيمها ضمن عدة أبعاد. 


الحد الأقل لبعد أي مصفوفة هو0»وكما اشرت بالشرط ٠٥×‏ 0 عند تعريف أو إعادة تحجيم المصفوفة9” ا١‏ 0أئمع "الع .بإمكانك عملياً إزالة 
الجزء من العبارة”٠٠‏ 0".وتعمل على تضمين فقط الحد الأعلىل,uهظ‏ ۲مممں . 


1 az These two lines are equivalent. 
Di animal (O TO 25) AS SEEING 
DAM amma lL (ZS) RS SEEING 


هاتان العبارتان كلاهما يعملان على إنشاء مصفوفة ب26 عنصر.مرقمة من 0 إلى25.يوجد العديد من الحالات الخاصة حيث يتم السماح للحدود 
الأدنى غير صفر. كالعمل مع المصفوفات الأقدم المولدة عن تقنية برمجة المكونات كإة۲۲ة dعأجاممعو-0K0M.ولكن‏ تركيب التصريح القياسي 


10 البيانات وأنواعها. 


في الفيجوال بيسك لايسمح لك بإنشاء مصفوفات مع حدود دنيا غير الصفر(آي دائماً الحد الأدنى هو الصفرئل”uهط‏ owerا nonzero‏ ).لتحديد 
الحد الأدنى والأعلى الحالي لبعد مصفوفة»استخدم الدالة ل80 1والدالة u٩‏ 8. 
MsgBox TRE Soard ls € GC QUEOUNIKER Ela LSSBOSET OE O‏ 
A E (UBound (ticTacToeBoard, 2) 2 10‏ 
إذا كانت مصفوفتك تحتوي فقط على بعد واحد»فليس عليك أن تخبر عن الحد الأدنى أو الحد الأعلى لأي بعد تريد أن تتحقق منه. 
MsgBox ("The upper element is numbered " & UBound (animal) )‏ 
تتضمن كل مصفوفة آيضا الطريقة d4 ةقيرطلاوüetاkoسwer8B 0u ٣d‏ er8B0uمpمpل6etواللتان‏ تعودان بنفس النتيجة التي يعود بها كل من 4٣اه‏ 8او 
Bound‏ على الترتيب.مهما يكن رقم البعد الذي تمرره إلى الطريقة ۲80۷ع W«٠0ااع6والطريقة ١4‏ ۲80uعمملااع6يبدا‏ من الصفر0ءبينما القيم 
بالنسبة 18014و 04 80uلاتبدا‏ العد من 1. 
MESO (ME oar dS ¥ CGC (ELCUECTOSSIOEEl EIEIO FU C&C |‏ 
TbByY TCE (EEE ClOeBOSLd Ge UpPErEOUNE OD)‏ 


حالما تصرح عن عناصر مصفوفتك» بإمكانك تخزين واستخراج العناصر عندما تحتاج لذلك.ومن الممكن أيضاً تخزين العناصر في مصفوفتك حالما 


تصرح عنها.وتظهر قائمة العناصر الجديدة في مجموعة ضمن حاصرتين(قوسين مدببين5ع€C٥٤5۲3 ٤1۷۲1۷‏ ) 
Dim SGuares( ) AS Integer = (0, 1, 4, 9, 16, 25}‏ 


عليك عدم وضع مواصفتي الحد الأدنى والأعلى ءماهعاfاعممs and upper bound‏ امسا عند إنشاء مصفوفة بهذه الطريقة,فمصفوفة "المربعات ءعإها۹ء 
"المبينة هنا سيكون لها عناصر مرقمة من 0 إلى 5 


متغیرات الأنواع ذات القيمة تعمل بشکل جيد جداً »تحفظ قيم بياناتها مدة عمرها .والأنواع المرجعية تعمل يا بشکل جيد»ولکن يمکن 
بلاشيء و9١1٣اه.‏ وهذا الاختلاف قد أصبح شوكة في جانب الأنواع ذات القيمة.ولكن مع الإصدار فيجوال بيسك2008, أصبحت الأنواع ا 
القيمة الآن من الممكن إسناد لها لاشيء9” ١ه‏ . وهذا النوع الجديد "بدون قيمة 7/6/6 " أساسي عندما تريد أن تكون لديك حالة غير 


محددة من أجل نوع ذو قيمة قياسي(وهو مفيد خاصة عند العمل مع حقول قواعد البيانات).خذ هذه الفئثة والتي تدير معلومات موظف: 
Public Class Employee‏ 


ENA Class 


تعمل هذه الفثة بشکل جید.ما عدا "تاریخ الطرد ۴۱۲۵03۴ " فهو ليس صحيح. بشكل افتراضي»سيتم وضع تاريخ الطرد 8ا۲۵0آ۴إلى 1كانون 
الثاني »سنة1بعد الميلاد12:00ء وتستطيع استخدام ذلك التاريخ وكأنه تاريخ "عدم الطرد".ولكن ماذا سيحدث إذا ما طردت شركتك أحدما تماما 
في تلك اللحظة »هل سيكون قد مر قرنين؟لحل مثل هذه القضية»تتيح لك الأنواع "بدون قيمة عاطةاالا" " من إسناد واستخراج لاشيء من 
متغيرات للنوع ذو القيمة. هذا الفيتامين يغني ٠۲٠١١۴١‏ الأنواع ذات القيمة ويتم التصريح عنه باستخدام تركيب علامة الاستفهام الخاصة. 
TEE E ETT GED EET GEE REG‏ 
Public FireDate As Date?‏ 
Public FireDate2? As Date‏ 


کل من هاتين العبارتين سیعمل ولکني أفضل العبارة الأولى»بحيث يتم إضافة علامة الاستفهام إلى لنوع البيانات.وحالما يتم التصريح.يمكن للنوع ذو القيمة أن 
يأخذ إما بيانات قياسية أو لاشي»ء. 
FireDate = Nothing‏ 
FireDate = #7/18/2008#‏ 
TE (EreDate 1S NOEHIDNG) Then...‏ 


يوجد و اص عند تعریف أنواع ذات قيمة خاصة بك ك"بدون قيمةعاطھااا" ".ولكن بما أنها تستخدم مواصفة الفيجوال بيıسك" generics‏ 
5 الفصل 16 لك. 


في هذا المقطع الأخير ساعمل على تضمين قوائم بالدوال الجاهزة في الفيجوال بيسك.والعديد منها ستستخدمه بانتظام في تطبيقاتك. وأيضاً 
ما تم جدولته هنا بعض من أعضاء فنة إطار العمل (ا٣۴) ork Cاass Library‏ ۴ramewوالتي‏ تكرر مواصفات كانت جزء من لغة الفيجوال 
بيسك قبل الدوت لى إطار العمل من أجل إمكانية وصول عامة. 


تتيح لك دوال التحويل من تحويل واحد من نوع بيانات الفيجوال بيسك إلى نوع آخر.وليس لك الحرية الكاملة من أجل الكل.لذلك لا تذهب بعيداً 
وتعمل على تحویل النص "مر حا" إلى قيمة عددية صحيحة وتتوقع منها أن تعمل .ولكن تحویل الأعداد من نوع عددي إلى اخر ءأو تحویل الأعداد 
بين الأنواع العددية والسلاسل الحرفية يعمل بشكل عام جيدآً.كل هذه العبارات (ماعدا ٤۲۷۲۴‏ )لديها نفس التركيب: 

dest = CXxxx(source) 
حيث 561۲66 هو القيمة التي يجب تحويلها بواسطة»655[.ليس عليك إسناد النتيجة إلى متغير مائ26 .تستطيع استخدام النتيجة في أي‎ 
مكان ترغب به كما هو الحال مع قيم المتغيرات والقيم الحرفية»يبين الجدول التالي دوال التحويل.‎ 


يحول قيمة ما إلى بايت مارم 


يحول قيمة ما إلى تاريخه)ه .إذا كانت القيمة المصدرية هي سلسلة حرفية.فيجب أن تكون في تنسيق وقت أو تاريخ صحيح. 
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يحول قيمة ما إلى عشري اه"iءه0.‏ 


يحول قيمة ما إلى طویل .Long‏ 
يحول قيمة ما إلى بايت بإشارة مارS8.‏ 


يحول قيمة ما إلى مفرد ماوہا؟. 


Dim xX ZS SENI 
xX > CIVOEe(S, SEFINS) 


يحول قيمة ما إلى عددي صحيح بدون إشارةه وهال . 


يحول قيمة ما إلى قصير بدون إشارة †مم5ل. 


ريخ والوقت.يجدول الجدول التالي هذه الدوال.معظم هذه الدوال تقبل معامل 
بخ€ا0a‏ »سلسلة حرفية S١١١9‏ أو نتيجة عددية .numeric result‏ 


تتضمن الفيجوال بيسك العديد من الدوال المصممة لإدارة قيم التا 
احد أو اکثر.وتعمل على إرجاع إما تا 


نسبی 3۲91۳6۸ مصدري واحد 


يضيف أو يطرح قيمة تاريخ أو وقت إلى تاريخ البدء.مثلاءتستطيع إضافة 12دقيقةءأو طرح ثلاث سنوات من تاريخ 


. تعود بمكون واحد لتاريخ أو وقت.مثل ساعة أو تعود بسنة‎ DatePart 


DatesString‏ تعود بالتاريخ الحالي كسلسلة حرفية.تستطيع أيضا وضع التاريخ على كمبيوتر محلي باستخدام هذه الكلمة المحجوزة. 


Day‏ تعود باليوم من قيمة تاريخ معطى. 
E GS O EE Tam‏ 


4 


> 
35 
® 


.12 تعود باسم الشهر من قيمة شهرية عدديةءمن 1 إلى‎ Month Name 


تعود بالثواني من قيمة وقت معطى. 


0n 
® 
0 
O 
رت‎ 
[e 


تعود بعدد الثواني التي مرت منذ منتصف 04 ير آتكاتي !5 £ اك :3737 ى 350 ى نة 


= 
3 
® 
® 


TimeString‏ تعود بالوقت الحالي كسلسلة حرفية.تستطيع يضا وضع الوقت الذي 5 کمبیوتر محلي باستخدام هذه الكلمة المحجوزة. 


Today‏ تعود بالتاريخ الحالي. 


WeekdayName‏ تعود باسم اليوم من الأسبوع بالنسبة ليوم عددي صحيح من أسبوع. 


المتغيرات التي تم إنشاءها ك ع۲1۳عاaم(.”٠عاكركS‏ (او تاريخ من فيجوال بيسك)كلها تتضمن العديد من الخاصيات والطرق والتي توفر مواصفات 
مشابهة للدوال المجدولة في الجدول السابق»على سبيل المثالءالخاصية "ثانية" تعود بعدد الثواني. 
Dim meetingTime As Date‏ 
meetingTime = #11/7/2005 8:00:03 AM#‏ 
MsgBox (meetingTime.Second) ' Displays '3"‏ 
MsgBox (Second (meetingTime)) ' Also displays EN‏ 
تستطيع إما استخدام دوال الفيجوال بيسك الجوهرية(القاعديةءاك١‏ آ٣ا"‏ ) او ما يكافئها من طرق وخاصيات ع" ۲عاn”.2aعstرS‏ في كودك .وكلا 


تتضمن الفيجوال بيسك الكثير من الميزات للعمل على نحو مدهش مع الأعداد. بالإضافة إلى المعاملات التي تعالج البيانات» يجدول الجدول 


التالى العديد 2 الخاصة بالأعداد. 
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FormatCurrency‏ تنسق عدد معطی كقيمة currencyilne‏ .باستخدام تنسیقات لمجموعة صغيرة معرفة مسبقاً. و هذه الخاصية تم تضمينها من آجل 
التوافق العائد لكود صيغة فيجوال بيسك المصغرة امأ ۷8S‏ الأقدم. 


FormatPercent‏ تنسق عدد معطی كنسيبة مئوية.باستخدام تنسیقات لمجموعة صغيرة معرفة مسبقاً .و هذه الخاصية تم تضمينها من أجل التوافق العائد 
لكود صيغة فيجوال بيسك المصغرة الأقدم. 


8 
3% 
3 

3 

5 
¥ 


IsNumeric‏ تشير فيما إذا البيانات الموفرة لهذه الدالة هي عدد محقق إمطصںم لااج۷. 

Val‏ تستخر ج العدد المحقق الأول امطصنم لاام ۲ا من نص و”آ٣)ءوترجع‏ به. 

ضفن إطار غخل الذوت نت الكة اه١‏ ٠ا55‏ دالتي تحتوف الكعذيد من أعضا النواك المكافة الى اضات كي مال فف وا5 د 
وهاء تم تنفيذها كدوال جوهرية في الفيجوال بيسك6:ءولكن تم نقلها من اللغة إلى الفئة ١ة۷في‏ الدوت نت. 

تتضمن الفيجوال بيسك أيضاً العديد من الدوال المستخدمة الحسابات المالية اهأ) 3١‏ أ#والإحصائية(أو المحاسبة 9١ا١‏ لا0٤ة‏ ).وكانت هذه 
الذوال مضمنه في الفيخوال يسك 6 ويها أنها لست على علافة بالمشرئ الذي ننافضه في هذا الكتاب ,لذلك سأجمل فقط على جدولت 


IPmt, IRR, MIRR, NPer, NPV, Pmt, PPmt, PV, Rate, SLN, and SYD.. DDB, FV,: li E 


معالجة السلاسل الحرفية هو جزء جوهري من برمجة ويندوز.ميزة ا ×الجديدة المضمنة مع الدوت نت هي إجراءات روتينية ١9-‏ ]٣ك‏ 

routines‏ ationاmanipu‏ لمعالجة النصوص بشكل رائع »على الرغم من التعقيدات المخفية Wع‏ أ۷ ۴۲٥۳‏ ٣عل‏ لا التي معها. 

تتضمن الفيجوال بيسك العديد من الدوال المصممة لمعالجة السلاسل الحرفية كو”|آ٣اءوالحروفك۲عاءة۸3۲»‏ .وهي مجدولة في الجدول التالي 
وکما کک الأخرى»هذه الدوال تعود بنص جديد أو قيمةءتترك النص الأصلي أو القيم المصدرية سليمةا٤ها١|‏ .والاستثناء 

loneJ 1‏ عبارة ١1ء‏ والتى تعدل القيمة المصدرية لمتغيرValue‏ ble’'sۆVariab source‏ , 


لعدد معطی»فان هذه الدوال تعود بما يطابق هذا العدد من حروف الآاسكي أو اليونيكود Unicode‏ . 


تنسق قيم عدديةءأو تاريخ أو وقت باستخدام أكواد تنسيق خاصة أو معرفة مسبقاً. 


تعود بموضع مجموعة جزئية ضمن سلسلة حرفية أكبر. 
تعود بسلسلة حرفية واا)ومبنية من سلسلة نة" ء†concaمصفوفة‏ من السلاسل الحرفیۂووہ|اء array f‏ . 


تعود بالحصة اليسارية اومص|۴ه| من سلسلة حرفية. 


تعمل تجانب لليسار ضمن سلسلة حرفية أكبر بالمساحة(الفراغ). 


تستخرج مجمو عة نصية جزئية من وسط ماله سلسلة حرفية أكبر. 


TTS 
.كمااأام١ تقسم نص إلى مصفوفة من مجمو عات نصية فر عية بالاعتماد على محدد معين‎ 
تقارن سلسلتين نصيتين »وتعود بعدد صحيح يشير إلى أمر ترتيبهما ۲م0۲ أ60۲.‎ 
تولد نص يحتوي عدد مخصص من حرف معين.مشابهة للدالة همهم5.ولكن تعمل مع أي حرف.‎ 
E TETER EET 
مشابهة للدوال المجدولة في الجدول السابقءعلى سبيل المتالء تعود الخاصية ١٣و١6 ابعدد الأحرف في سلسلة حرفية.‎ 
Dim simpleString As String = "abcde" 

MSGESOxX (SAME eS EE ANS Hen SIER) CDSS OF 

MsgBox (Len (simpleString)) ' Also displays 5 


بامكانك اام اما دوال ۰ بيسك lلتlاعدية intrinsic Visual Basic functions‏ أو ما e‏ من طرق وخاصیات وˆ|!۳.5†۲٣ Syste‏ في 
ك. لنتيجة.على الرغم من أن تفاصيل التركيب والخيارات يمكن أن تتنوع(تختلف ۷3۲۷ ). 


تتضمن الفيجوال بيسك العديد من الدوال التي ترفض أن تكون مقحمة لهz٠هںووفي‏ أي من التصنيفات السابقة.يجدول الجدول التالي قائمة بهذه الدوال. 
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تحول قيمة ما من نوع بيانات إلى أخر.و يجب تحديد نهاية وبداية نوع البيانات.مشابهة للدوال ائة٣ر۲آو‏ ممرآ٥.‏ 


ک 
3 
د 
o‏ 
ك 
n‏ 
E‏ 


تشير فيما إذا البيانات المزودة لها مصفوفة محفقة( صحیحۂةرھ ۾ valid‏ 


8 
> 


تشير فيما إذا البيانات المزودة بها حالة خط .error condition‏ 


n 
TM 
¬ 
° 
9 


IsReference‏ تشير فيما إذا البيانات المزودة بها هي نوع مرجعي أو نوع ذو قيمة. 


w 


RG‏ تعود بكود اللون المبني من المكونات المستقلة للأحمر»الأخضرءوالأزرق. 


تحول قيمة من نوع بيانات لأخر.ويجب تحديد نوع بيانات البداية والنهاية.مشابهة للدوال هع هء¡5و ممypاC.‏ 


4 
ک 
0 
ك 
2 


TEE FET TIET TIE HETE 


| 
ك 
لح 
mm‏ 


سنستخدم في هذا الفصل ميزات كل من الدوال ونوع البيانات التي درسناها »كل الكود في هذا الفصل سيظهر في وحدة برمجية للفيجوال 
بيسك مسماة "عامةا8۲2 "6€ " وسيتم تخliıj‏ ڊm~l۾ .General.vb‏ 

لقد عملت على إضافة ملف مع وحدته البرمجية وتعريف الوحدة البرمجية يظهر كما يلي(افتح قالب مشروع ويندوز واعمل على إضافة وحدة 
برمجية له من قائمة مشروع٣٤۲۴۸03>‏ >إضافة وحدة برمجية عاuال١ه"‏ وسمها ۷2 ./2/ع//٥6‏ )واضف في بداية تعريف الوحدة البرمجية الكلمة 


المحجوزة ۵٣eا٣۴.‏ 


Friend Module general 


End Module 
کما ذکرت کل الکود الذي سنضيفه في هذا الفصل سيظهر ضمن هذين السطرين.تذكر أن الوحدات البرمجية تشبه كثيراً الفئات‎ 
والتراكيب»ولكن لاتستطيع إنشاء حالة منهاءفكل اعضاءها تتشارك مع جميع اجزاء كودك المصدري.وهذا ما يتيح لها الاستخدام في اي مكان‎ 
في التطبيق.لانحتاج لعمل اي شيء خاص لجعلها متاحة لكامل البرنامج. إلا وضع إمكانية الوصول لكل عضو عند الحاجة.في البداية سنعمل‎ 
على إضافة بعض الثوابت العامة المستخدمة على طول البرنامج.اضف الكود التالي بين السطرين السابقين كما يلي:‎ 


Friend Module general 


Public Enum LookupMethods As Integer 
ByTitle = 1 
ByAuthor = 2 
BySubject = 3 
ByKeywordAny = 
ByKeywordAll 
ByPublisher = 6 
BySeries = 7 
BySeriesID = 8 
ByBarcode = 9 
ByDatabaseID = 10 
ByAuthorID = 11 
BySubjectID = 12 
ByPublisherID = 13 

End Enum 

Security values.‏ سڪ ل 

Public Enum LibrarySecurity As Integer 

ManageAuthors = 1 

ManageAuthorTypes = 2 

ManageCopyStatus = 3 

ManageMediaTypes = 

ManageSeries = 5 

ManageGroups = 6 

Manageltems = 7 

ManagePatrons = 8 

ManagePublishers = 9 

ManageValues = 10 

ManageUsers 1 

ProcessFees 2 


ll | 
NS 


1 
کا 


= 1 
= 1 
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ManageLocations = 13 
CheckOutItems = 14 
CheckInlItems = 15 
AdminFeatures = 16 
DailyProcessing = 17 
RunReports = 18 
PatronOverride = 19 
ManageBarcodeTemplates = 20 
ManageHolidays = 21 
ManagePatronGroups = 22 
ViewAdminPatronMessages = 23 

End Enum 

Public Const MaxLibrarySecurity As LibrarySecurity = LibrarySecurity.ViewAdminPatronMessages 


End Module 
هذه الثوابت و العدادات توضح نفسها »سيتم استخدام ١٥0اك۲ه08۷عءلالضمان أن التطبيق يطابق قاعدة البيانات المستخدمة عند إتاحة عدة‎ 


إصدارات منها. 
lلiوlبٽ p“axwMatchNone 9 MatchPresent‏ استخدامها لعمليات بحث بنود المكتبة.يعرف العدادان الأكواد التي تعين نوع بحث بنود المكتبة 
لإنجاز (طرق بحث ءل0ط†Meم100kup)ءو‏ أكواد الأمن تستخدم لحصر الميزات التي سيكون مدير ما ۲20۲١‏ †كارİ"‏ كه قادر على عملها في 
lلتطبJıق (LibrarySecurity)‏ 
حان الوقت لإضافة بعض الطرق.الطريقة الأولىا×6 ٣8۲ا"‏ ».تمركز سطر من النص ضمن عرض معين.للمثال»إذا كان لديك نص " W0۲1‏ ,هاا 
"(12حرف في الطول) وأردت وضعه في مركز سطر يمكن أن اک بطول 40حرق.ستحتاج إلى إضافة 14فراغ لبداية السطر(محددة بطرح 
12 من40»ومن تم تقسيم النتيجة على 2).یستخدم الإجراء زوج من دوال الفيجوال البيسك الخاصة بالسلاسل الحرفية(متل Left «Trim‏ 9 
٣ا)لمعالجة‏ واختبار البيانات»ومعامل القسمة الصحيحة | للمساعدة على حساب عدد الفراغات التي يجب إدخالها. 
Public Function CenterText (ByVal origText As String, ByVal textWwidth As Integer) As String‏ 
ل و من الت ن درک ار در _ اا د رر ادا کان الت کل د ده 
Dim resultText As String‏ 
resultText = Trim(origText)‏ 
IF (Len (resultText) >= textWidth) Then‏ 
االار ج ا 
Return Trim (Left (origText, textWidth) )‏ 
Else‏ 
EEE E EO TE EET‏ 
RE EUER SBDACe ( (EOXENAdAEM € Wen OrIGIexXE)) 2) GC EESUIEleSE‏ 
End Uf‏ 
ERA EUME E OM‏ 
BUGLE EURNCENON Let EANIRIGNENEeXE (BVVUaAN SEISLEEE AS SEEING, BYVAL OLIIRIORE AS SEEING,‏ 
ByVal textWidth As Integer) As String‏ 
ا ص ماما ادد رلادة نص وط علق جن وبمار الط ' 
Di leEELeExXE AS SEBIR‏ 
Dim rIGhELext AS SCEING‏ 
leftText = Trim(origLeft)‏ 
riIghtEText = IrFIM(OLIORIGRE)‏ 
If (Len (leftText & rightText) >= textWidth) Then‏ 
Return Trim (Left (leftText & rightText, textWidth) )‏ 


Else 


Return leftText & Space (textWidth - Len (leftText & rightText)) & rightText 
ERA TÊ 
Ena EUME ES OM 
تبدأً الدالةا×6١€6۸۲6۲| بعمل نسخة من النص الأصلي(ا×٠٣9١0)ء تزيل أي فراغات إضافية بالدالة ۳١۲.ومن ثم تختبر تلك النتيجة لرؤية فيما إذا‎ 
ستتناسب على السطر.فإذا لم تكن كذلك.فإنها تقطع ۴ه كمهاء حروف التذيل والتي تكون زائدة(غير متناسبة)ءوتعود بتلك النتيجة. من اجل‎ 
النصوص التي تتناسب والسطر "٣ال ۷× ااتساع الحروف»تضيف الدالة عدد مناسب من الفراغات لبداية النص»وتعود بالنتيجة.يضيف الكود‎ 
۲ا وeftAndRiا. تعمل تماما مثل الدالة ×٠٠۲ع1١).ولكنها تضع سلسلتين نصيتين مختلفتين عند أقصى النهايات‎ e× السابق دالة مسماة‎ 
اليسرى واليمنى لسطر النص.‎ 
الآن إلى الجزء الثالث من الكود.يضيف هذا الجزء إجراء مسمى ۷ا١50أوا0.يعمل على بناء نص جديد مركب من الأرقام فقط الموجودة‎ 
لکل حرق فی ×۴ 0۲19۲ واحد واحد.فکل رقم موجود یتم‎ NU۳۴۴٤ في النص المصدري» ×۲۴ 0۲19 وهو يعمل هذا باستدعاء الدالة‎ 
.des1€×† سلسلتەه(إلحاقه بالتسلسل)|إلى نهاية‎ 
PUBL IE HUNE OM DigitsOnly (ByVal Origlext AS SEriIng) AS SEFInG 
اا و ا ن کے که کد‎ 
Dim destText As String 
Dim counter As Integer 
٠ احاار كال رك‎ 


destText = "" 
HOE GCOUNEEE 1 TO LenNn(OEIIUeXE) 
IE (USNS TE (ME CE LEE, CONES, LY TM | 


destText &= Mid(origText, counter, 1) 
Next counter 
Return destText 
ERO HUnMie E OR 
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الدالتين الأخيرتينء Str‏ 0untSuوetSubStr‏ .تحسبان وتستخرحان نصوص فرعية substrin9s‏ من نصوص آکبر بالاعتماد على 
محدداع†أ"ااعd‏ . تتضمن الفيجوال بيسك دالتين» M14‏ و ۸3۲ ٤6€.تستخرجان‏ أأيضاً نصوص فرعية من نصوص آکیں ولکنهما يعتمدان 
على موضع النص الفرعي.تتفحص الدالتين ١5ط5uا‏ هو ”tكubك6etالنصوص‏ الفرعية أولاً باستخدام المحدد delimiter‏ 
لتقسيم النص الأكبر في أجزاء. 
PUBIIE FUnNCEION COUNESUSSEE (BVVal man lext AS SETING, BVVUal SUDLOexXE AS SEARO) 3E Integer‏ 
ال ا ا د ا ا ا ج م و ہد جک سے نے کت اا ٢:‏ 
Dim totalTimes As Integer‏ 
Dim startPos As Integer‏ 
Dim foundPos As Integer‏ 
totalTimes = 0‏ 
Stat EBOS = 1‏ 
اة ال حي 1 يا هه لص احرني اا 
Do‏ 
لحت عن اس او 
foundPos = InStr (startPos, mainText, subText)‏ 
TE KESUNGAEOS <= O) en EXE DO‏ 
totalTimes += 1‏ 
E A EN‏ اد ا 
startPos = foundPos + Len (subText)‏ 
Loop‏ 
ا ا 2 
Return totalTimes‏ 
ERG EUNE EI OR‏ 
EUDLIE EUNCELON GeESUOSIEE (BVUAL OEIISSEE1NG AS SEIN, BVVGAL Gelim AS SEFING, ByYUal which eld AS‏ 
Integer) As String‏ 
اسر اج اس عا اد سین من ت اك ' 
DIM SErIMGEAEE SK) AS SEEING‏ 
ن ا 
TE wuhzeRhETeLS < O) Then RelruUEn OL‏ 
TE (EON (OGEIGOSETING) € U) Then Eel‏ 
TE (len (delim) — O0) Then ReECUENn WT"‏ 
اح التم الل لل أا دة ك 
SELA RGSEAEES < SOI EIOEIOSELINO, GdeELEM)‏ 
مكرى هل ار الاي تخرندة مو حجودو قاد كان كلك لتر حك 
TE hie eld > UEOUNO(SEEINTEATESYD 1 Ll) Ten RECUEN 11 ElGSe RELEUEN SEEINSEAEES (MALEN eNS E 1)‏ 
ERG EUNE EI OR‏ 
تحسب الدالة ٣5طںu)Sهعدد‏ مرات ظهور نص فرعي في نص آكبر.وتستخدم دالة الفيجوال بيسك ٣)5م|‏ لإيجاد موضع النص الجزئي(۲×٠طںء)‏ في نص 
أكبر ٠×٤(‏ ١اه‏ ).و تحافظ على عمل هذا حتى الوصول إلى نهاية ٣ ٠×۲‏ هم »و المحافظة على تشغيل الحساب(ءه٣|٣|هاه))‏ لعدد التطابقات. 
ولتكون على دراية أكثرءقمت باستخدام مقاربة مختلفة لتنفيذ الدالة؛SطںSمى‏ .وهذه الدالة تعود بمقطع محدد من نص ما. على سبيل المثالءالعبارة التالية تحصل على 
portion‏ imitedاde-aصصmدc‏ الجزء المحدد بالفاصلة الثالث للنص وہا٣Sواط.‏ 


BA GS EARNS - abe, dEE, GNI, JCL MRO 
MsgBox (GetSubStr (bigString, NT DDN CS DISBLAVSE ghi 
استخدمت دالة الفيجوال بيسك †ام5لتقسيم النص الأصلي(و”1ء؛Sواءه)لعدة مصفوفات أصغر من النصوص(5ا٣ ۴2وہ )ء)ءباستخدام صiاملكنقطة تقسیم .ومن ثم‎ 
عملت على إرجاع رقم العنصر ١اه ۴ء اسمن النتيجة.بما أن ١اه ا۴ء ايبدأ ب1 والمصفوفة تبدأً ب0»فيجب علي ضبط الموضع للعودة بالعنصر الصحيح.‎ 
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نماذج ویندوز Windows Forms‏ 
تقنية الدوت نت المعروفة بنماذج ويندوز ۴075 ۷/7205 تتضمن كل الفثات والميزات المطلوبة لتطوير تطبيقات "سطح مكتب"قياسية 
زوفت وتدورولقد أصبحت الانؤاح فن أنوا ع التطيقات الواخة على طول مع ات الكوسول مهات الارن 
.والتطبيقات الخدمية ...إلخ. 


عندما تتفاعل مع ويندوز فمن السهل عليك(كإنسان)أن تلاحظ النماذج المختلفة والأدوات التي على الشاشة.فبإمكانك التفاعل مع هذه 
النوافذ من خلال لوحة المفاتيح والماوس»يحتفظ ويندوز بقائمة النوافذ المعروضة على الشاشة. كيف تتداخل ويغطي بعضها الآخرء ولأي 
تطبيق تنتمي كل نافذة.(بعض التطبيقات تكون مجزأة إلى عدة مسارات ٣۲6405‏ وجميعها تعمل في نفس الوقت.في مثل هذه البرامج 
يحتفظ ويندوز بمسار جميع النوافذ على قاعدة كل مسار»وليس على قاعدة كل تطبيق فقط). يحدث كل إجراء مدخل من قبل 
المستخدم(متل نقرات الماوس وضغطات المفاتيح)في طابور رسائل النظام عاعماQ‏ 296ككم" ”عائرء بواسطة ل معرف di۷۵6۲‏ ) 
الجهاز ذو الصلة .فعندما تنقر على الشاشة بواسطة الماوس یستخرج ویندوز رسالة النظام من هذا الطابورء محدداً أڻ نقرت» ومحاولاً 
استكشاف أي نافذة حدث نقر الفارة عليها»ومن ثم إعلام تطبيق ويندوز حول نقر الفارة بإضافة رسالة إلى طابور رسائل التطبيق.ويعمل 
نفس الشيء»ء من أجل إدخال لوحة المفاتيح والإجراءات الأخرى التي ومن المحتمل يحتاج ويندوز أن يعرف شيء ما حولما. 

لعمل وظيفة ضمن بيئة ويندوزءيتضمن تطبيقك(أو مسار معين ضمن تطبيقك)مضخة الرسائلم ”01۷/7 7€55298/ »وهي مقطع من الكود 
يراقب طابور الرسائل.تتضمن كل رسالة قادمة(او داخلة) رقم المعرف 0اللنافذة المقصودة.يستخرج الكود الرسالة من الطابورء ويمررها 
إلى إجراء النافذة( ويدعى أيضاً 72۶/٥٥‏ )للنافذة المالكة من أجل المعالجة النهائية.في لفة ٥‏ تبدو مضخة الرسائل هذه مشابهة 
للتالي: 


while (!done) 


/* ----- Extract and examine the next message. */ 
MSG msg; 
if (GetMessage(&msg, NULL, 0, 0)) 


{ 
/* ----- WM_QUIT means it's time to exit the program. */ 
if (msg.message == WM_QUIT) 
done = true; 
/* ----- Send the message to the right window. */ 
TranslateMessage(&msg); 
DispatchMessage(&msg); 

1 


1 
بالتالي کل e‏ »کل مسار صمن تطبیق )لدیه مضخة رسائل واحدة وإجراءات متعددة لكل نافذة .توحد مضخة الرسائل لتمرير أو 
إرسال الرسائل إلى إجراء النافذة | 1 


بما ان مضخة الرسائل ترسل الرسائل إلى إجراءات النافذة المستقلة»يوجه روتين إجراء النافذة ع٥۴۴۲‏ ١"۷المعالجة‏ إلى مقاطع الكود 
المستقلة أو الإجراءات المعتمدة على نوع الرسالة القادمة.إليك منطق عام(شبه كود) يوضح تركيب إجراء نافذة نموذجي: 
Tf (message type is a mouse click)‏ 
Do mouse-click related code‏ 
Else If (message type is a key press)‏ 
Do key-press related code‏ 
Else If (message type is a window resize)‏ 
Do window-resizing-related code‏ 
EIS...‏ 
(يستخدم شبه الكود عبارات ۴ا المتتاليةولكن عملياً يستخدم إجراء نافذة بشكل أكثر شيوعاً عبارة "اختر حالةمءaع‏ اءمامS‏ "لمعالجة 
الرسالة القادمة).لذلك »يشبه إجراء النافذة آلة البيع»إذا ضغط الزبون زر الكولاء تقوم بمعالجة ما يعيد بعلبة كولا.وإذا ضغط الزبون على زر 
العلكةءتقوم بمعالجة ما يعيد علكة.وإذا ضغط الزبون على زر إعادة العملة المعدنية» تحتفظ بالنقود. 
من أجل كل نوع رسالة(على الأقل بالنسبة لتلك التي يريد البرنامج معالجتها) ر عالت ع الك ها تصل الرسالة.فإذا عدنا 
إلى الفيجوال بيسك1.0ءجميع التطبيقات المولدة تتضمن مضخة رسالة joWndProc تlءlرج|lو message pump‏ أجل کل 
نافذة» وجميعه مخفي.المهمة الرئيسية لإجراءات ١٥٤٥۵۴۲١"۷/كان‏ استدعاء الكود في معالجات حدتث الفيجوال بيسك. 


خذها من شخص اعتاد كتابة تطبيقات ويندوز في لغة سي :كتابة مضخات الرسائل كم"٣نام‏ مومssمص‏ وإجراءات النافذة window‏ 
oceduresام‏ ليس بتلك السهولة.عملت ميكروسوفت على محاولة تقنيع بعض الملل من خلال تقنيات متنوعة»من ضمنها فاحص 
الرسالة sامackاC Message‏ وفئات إطار العمل 1۴٣‏ .وفي النهاية نحجحت فيجوال بيسك في دفن التعقيد تحت النظام المنطقي القريب 
من llمبرمج programmer-friendly logical syste‏ . 

یستخدم إطار عمل الدوت نتW۵۲۸ ۴۲۸۳٥‏ ۴۲.. نظام مشابه تماما للتنفيذات الأقدم في الفيجوال بيسك.»باحتواء إجراء النافذة 

WndP roc‏ استدعاء معالجات حدث خاصة مكتوبة من قبلك.فهو يحزم جميع الفعالية والبساطة في تقنية تدعى نماذج ويندوز 

Forms‏ sسWindo.جميچ‏ فئاتها تظهر في فضاء الأسماء ۲۳۶٥s.۴سWههہW1.٣۵اءرS.العديد‏ من هذه الفئات تنفذ أنواع معينه من النوافذ»مثل 
النافذة الرئيسية الاعتيادية, الأزرارء صناديق النصوص»قوائم الصندوق المركب المنسدلة»وهكذا. 
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إذا كنت تريد.مايزال بإمكانك الوصول إلى مضخة الرسائل م"۳ام موعدم" وروتينات إجراء النافذة ۴۲٥٥١‏ ۷"۵المتنوعة.تتضمن كل فئة 
خاصة بنافذة طريقة ١١٠١۷۷۵۴تستطيع‏ إعادة قيادتها وصنعها بنفسك.فمضخة الرسائل موجودة في الطريقة 

Application. Run‏ .System.Windows.Forms.تستطیيع‏ ان تامر اي من هذه المكونات والتحكم بكل شيء بنفسك »ولكنك ستكتشف أن 
معالح نماذج ويندوز ممتع جدآً»وستعمل بجد لتنسى حتى ما هي مضخة الرسائل م”٣uم‏ ٥529ء٠"‏ أو ما تعني. 


في الدوت نت وكما في إصدارات فيجوال بيسك الأقدم النوافذ تكون منضدة ضمن النماذج والأدوات.ولكنها ماتزال نوافذ»مبنية من نفس 

المكونات الجوهرية(القاعدية)ءإذا كنت لا تصدقني.راجع فئات النماذج المتنوعة والأدوات»ففي الدوت نت كل من النماذج والأدوات تشتق 

من الفئة المشتركة ٣0|‏ †٣System.Windows.۴orms.C0.والتي‏ تلخص التخصص الوظيفي الجوهري للنوافذ(نافذةس0Wل٣W‏ ). بعض الأدوات 

المزودة في الدوت کک مع فيجوال ا الأقدم)لاتنفذ عملياً على عناصر نافذة الشاشة»ءوهذه الأدوات مثل أداة "المؤقت۲ع" |1 
فهو لايتضمن على وا سة» برمجة حسية مشابهة للأدوات المرئية. 


New e 
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Yıisual Studio installed templates 


E windows Farms Application 13 Class Library 

Smart Device E3 WPF Applicatior FE WPF Browser Application 

Uftice Console Application e] Empty Project 

i: Database EE] windows SEIYICE ge WPF Lustom Cortral Library 
Programming visual Basic ZU gE WPF Liser Control Library {EE windows Farms Control Library 
Reporting 

j Test My Templates 
WCF 
Warkflony j search Unline Templates... 


Hl: Uther Languages 
Uther Project Types 
Hl: Test Projects 


û, project for creating an application with a Windows user interface [. NET Framework. 3.5] 
Name: Windowsê pplication 


اختر نوع المشروع ع۷ا tععزه۴r‏ "ویندوز W1 ۸40۷S‏ ".ومن ثم من نافذة القوالب کعاھام٣۳٥۲‏ اختر قالب تطبیق نماذج ویندوز ۷1۸0۷5 
icationاApp‏ ۴m.امنح‏ المشروع الاسم الذي تريد في حقل الاسمع" ة١‏ »ومن ثم انقر موافق0۸ .سيكون للمشروع الجديد 
فورم( نموذج ۴٥0۲٣۳1‏ )وحيد جاهز لتستخدمه.عند هذه النقطة»تكون الفيجوال استوديو قد اضافت حوالي250 سطر من الكود المصدري 
لتطبيقك.إذا نقرت على زر إظهار جمیع الملفات 5٥ا۴‏ ا۸ 5۸0۷ في لوحة مستکشف الحلول٣۴٤٣٥ہام×E‏ ۸٥ا‏ uاSo‏ (تم شرحھا سابقا في 
الفصل الأول)وافتح الملفات المتنوعة في المشروعء»بإمكانك رؤية الكود بنفسك.أهم ما في الكود في الملفط۷./€/2€5/9 ۶0/٣1.‏ تم 
تحدیثه قليلاً هنا: 

E CLAS OI 

Inherits System.Windows. Forms. Form 


"Form overrides dispose to clean up the component list. 
SEVIS EEM. DI AROS E1 CS. DEOL ISEENSNUSE RESETS 
Protected Overrides SUBD Dispose (ByVal disposing AS Boolean) 
TEY 
If disposing AndAlso components IsNot Nothing Then 
components. Dispose () 
End Tf 
Einally 
MyBase.Dispose (disposing) 
ا‎ 
EDA SUB 


"Required by the Windows Form Designer 
Private components As System. ComponentModel. [Container 


"NOTE: The following procedure 1s required by the Windows Eorm Designer 
"It can be modified using the Windows EoOrm Designer. 
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"Ds not modify iE USInS the Code edIEOF , 
<System. Diagnostics. DeBugIerStepIhEough () > 


components = New System. ComponentModel.Container () 
Me.AutoScaleMode = System.Windows.Forms.AutoScaleMode. Font 
Me.Text = "Forml™ 


ERG Clas 
.فورم‎ ystem.Windos. )في فضاء الأسماءك۲ه۴‎ ۴٥۲۳ كل الكود الذي ينفذ سلوك النموذج يظهر في فئة النموذج(الفورمككهاء‎ 
عكهط وتستقبل كل التخصص الوظيفي للفورم والإعدادات الافتراضية.واي تغيرات‎ ۴0۲٣٣ ترث من الفئة القاعدية‎ ۴0١۳١1 المشروع الأولية»‎ 
مثل إضافة ادوات أبناء يتم إضافتها إلى إجراء "التمهيد للمكونات‎ ۴0٥۲٣١1 وقت التصميم يتم عملها لواجهة المستخدم‎ 
آلي عندما تستخدم الفيجوال أستوديو.‎ لكشب""1tiaاieComponent‎ 
راجع هذا الروتين بشكل دوري ۷|اaء ال0 |8۲ملرؤية كيف يتغير هذا الإجراء.‎ 
معظم البرامج سيكون لديها عدة فورمات»افترض أن بإمكان الدوت نت اختيار واحد من النماذج بشكل عشوائي لعرض متى يشتغل‎ 
البرنامج للمرة الأولى. وهذا سيكون لهو وغير قابل للتنبؤ به عاطةاءاك١۲6م"ن .إنك تشير إلى نموذج بداية التشغيل و١ ا۲ةأكءمن خلال‎ 
ها5 " على تبویب التطبیق ٩٥ة‌ام‌م۸ (شاهد‎ ۲اںp‎ ۴٥۲٣ خصائص المشروع5ع همهم s'اcمزهام »بواسطة الحقل"نموذج الانطلاق‎ 
Prop€r†ie5 عندما تختار مشروع ز٥۴۲ >>أمر القائمة خصائص‎ مroزect's‎ properties الشكل التالي)(تظهر نافذة المشروع‎ 
„ Solution ExplorerJglzJl| éشكSتۃةwn‎ ٭١ف‎ My Project iı في اله یجوال أستوديوء أو عند ال: مزدوج على‎ 


9 WindowsÃApplicationl - Microsoft Yisual Studio 


Fils Edt Wem Project Build Debug ÛOata Tonls Test Windom Help 


SEE TEN E 
Toolbox we Hl 2 WYindowsApplicationl ° Form1.Designer. wb Form1.Yb [Design] Start Page | 


Application 

There are no usable controls Assembly name: Root namespace: 

in this group. Drag arı item - —_ - ج‎ 

onto this text to add it to Ihe Compile Windowsêpplicationl Windowsê pplicatior 
toolbat. 

Application type: Ison: 


Widows Forms Application ¥ | [Default leon] 


Startup form: 


Resources Farrnl پد‎ 


Foarmml 
Services Assembly Information... Yim lA Settings 


Settings 


Debug 


References 


zan0, BE J 3 1210 dx3 UOHIOS Ê 


Enable application framework. 


Saa Ta 


Windows application framework properties 
4 آ11‎ 


Î 3 Toolbox (a Server Explorer أ‎ 


Error List)‏ ۳ أ 


Ready 
عندما يبدا تطبيق الدوت نت يستدعي إطار العمل الطريقة المسماة ١أة۷افي مكان ما ضمن كودك.إنك أي نموذج رئيسي يتم‎ 
إن هذا الحقل يتضمن قائمة بكل النماذج »ما عليك هو اختيار ما تريد منها.ولكن أنتظر إنك‎ .' ' Startup form " استخدامه من خلال حقل‎ 
لم تضيف الطريقة "رئيسية 1ة "إلى أي فورم؟لامشكلة»إن الفيجوال بيسك ستكتب روتين(إجراء٤ ٣آ ا۲۵ ١ة )رئيسي بسيط دون‎ 
تدخل منك والذي سيعرض النموذج المشار إليه.هذا الروتين يتم إضافته وقت الترحمة» فيعمل فقط المعالجة الأقل المطلوبة لعرض‎ 
الفورم‎ 
إضافة روتين رئيسي مخصص لفورمك. أو إلى بعض الفئات الأخرى غير النماذج في تطبيقك.فهذا ليس بالمشكلة»إذا كنت لم‎ 
"المبين في الشكل السابق»على نفس تبويب الخصائص‎ Enabا٤‎ application framework "Jقتحئll تختار(لم تضع علامة صح( عل”‎ 
"تتفير لتضمين أي فئة في تطبيقك‎ Sاة۲أدم‎ ۴0۲١ المبين(لاحظ أنني قمت باختياره(وضعت إشارة صح فيه))القائمة "نموذج الانطلاق‎ 
فيها روتين رئيسي مناسب(موافقعاطاأةم٠٥» ).ولكن تطبيق إطار العمل يمكن الكثير من التخصص الوظيفي المقدر باعتدال امم‎ 

¡اunctionaگf.وهذا‏ کله بدون تدخل منك. هذا الخيار فقط عندما تحتاج تحكم دقيق على عمر التطبيق منذ البداية(مبكرا). 


إذا قررت كتابة روتين "رئيسي 131١‏ " خاص بك في فئة غير الفورم فإنك تريد في النهاية عرض نموذج تطبيقك الرئيسي.بالعودة إلى 
الفيجوال بيسك6, فعندما تريد عرض نموج ماءفإنك تستدعي الطريقة "أظهرŠ!0۷‏ ": 


3 
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Form1.Show 
هذا التركيب البسيط اختفى عندما ظهر الإصدار الأول للدوت نت من الفيجوال بيسك في2002ءولكن عاد مع الإصدار2005.قل إنك تريد‎ 
.أولاً تحتاج لإضافة وحدة‎ "ة١‎ ۴0٠۲٣١ طلا في وحدة برمجية عالاكه"مفصولة عن الفورم الرئيسي‎ N17 بداية تطبيقك من الإجراء‎ 
عدل كود الوحدة البرمجية الجديدة‎ . ۸4١ ×"ه١كuاعةيجمرب برمجية جديدة عاduم" إلى المشروع.اختر مشروعاءعزهإ۲۴ >>إضافة وحدة‎ 


بحيث يبدو مشابهة لمقطع الكود التالي: 
Module Modulel‏ 


End Module 

في نافذة خصائص المشروع .لا تضع علامة صح zJحaتJ" Enable application framework‏ ".واختر إما e1اModuأو Sub Main‏ من قائمة 
r‏ Startup.وھذا‏ بسیط جدآً.إذا شغلت البرنامج الآن»سيعمل البرنامج وينغلق بسرعة.في الحقيقة»ستظهر 1٣۲۳٥۴فقط‏ لحظة ِ 
مقتضبة قبل وجود البرنامج.لماذا لم تثبت ال ۴0۲٣1‏ ؟يتواجد البرنامج مباشرة لأن مضخة الرسائل المزعجة»أو بدقة أكثر العوز لمضخة 
lلرږilwئpumpJ Js. message‏ نافذة(أو فورم أو أداة)لديها إجراء "إجراء ويندوز ۷١0۴۲١٥١‏ ".ولكن يوجد فقط مضخة رسائل واحدة مميزة 
Pصuم message‏ لکل تطبیق او مسار تنفیذ 1۲٤۴۵۵‏ .فقي هذا البرنامج البسیطء ۴٥۲۸۳٣1‏ لديها إجراء "إجراء ویندوز ۷۸4۲۲0٤٩‏ " الخاص 
بهاءولكنه لايتحكم بمضخة الرسائل بنفسه.عليك على وجه التخصيص إخبار البرنامج ببدء تشغيل مضخة الرسائل "۷۳م ع29ءومص.بما 
ان مضخة الرسائل القياسية ٣۷م message‏ ndardهtء‏ لتطبيق نماذج ويندوز تظهر في الطريقة 
Application. Run‏ .System.Windows.Forms.عدل‏ کود Main‏ طSu‏ ليتضمنها مما يمكن المضخة ويحفظ الفورم1 معروضة حتی ز 

EEE Modulel 

Buble SUS Mas n0) 


el SUNS 
End Module 


بإمكانك إضافة جميع الأنواع للكود الممهد لإجراء" اة" طاS‏ »وإظهار النموذج الرئيسي ۴0۲۳١‏ ١أ"‏ فقط عندما يكون كودك جاهز للتفاعل 
مع المستخدم. 
إذا اردت إضافة نموذج جديد لتطبيقك»استخدم مث Project‏ >> إضافة نموذج iıgدmjgڵF0 Add Windows‏ .„ 


في الدوت نت كل النماذج هي فئات بسيطةءتنوع عن الفئة System. W1 ٣d0۷WS.۴0۲۳5.۴0۲۳‏ .كل مرة تعمل على إنشاء نموذج 
جديد. فانك تنشئ فئة مشتقة معتمدة على فئة النموذج المشتركةككهاء "۳0١ ۴١۲۳‏ . ويتم تحميل فئتك الجديدة مع التخصص 
الوظيفي» وهي تتضمن الحقولكءهلاعا۴ .الطرق كلهطاعمص.الأخطاءئونط . الخاصيات كعاا۲ممه١م,‏ والأحداث كأ" ع۷ء التي تركب فئة 
الفورم.تاخذ الفيجوال استوديو هذه العناصر وتجلبهم بطريقة تجعل منها سهلة البرمجة بالنسبة للفورم من خلال كل الكود المصدري 
source code‏ ومن خلال السحب والإسقاط 0٥۸4-4۲ه-و۲a‏ على واجهة المستخدم لمصمم نماذج الفيجوال استوديو Visual Studio‏ 
„Forms Designer‏ 

عندما تضيف نموذج ٥۲۳‏ اللمرة الأولى لتطبيقك»استخدم لوحة الخصائص كع )»مه٣۴۲‏ (شاهد الشكل التالي)لتعديل الفورم لما تحب 
.وهذه اللوحة تظهر الخاصيات المبدئية للبنود المختارة حالياً ضمن بيئة الفيجوال أستوديو.فهي تتضمن مدخلة مفصولة لإعداد كل 
خاصية. معظمها يمكن أن يتم تحديثه من خلال مدخلة النص ا×عاالبسيطة.على سبيل المثال»بإمكانك تعديل العنوان المعروض في 
أعلى الفورم بتبديل المحتوى لخاصية النص ×۲ من °۲۳1٥۴إلy Cool Form‏ 
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Properties 


Form System windows. Forms. Forrn 


MinimurmS ize U:0 
Dpacily 10U 
Padding UUU:U 
RightT oLeft Ho 
RightT oLeftLapouit False 
Showlcon True 
ShowlnT askbar RE 
Size 300: 300 


Size ripS kyle تا‎ 
StartPositior Windows D ef aultLaocatiar 
Tag 
cool form 
TopMost False 
Transparencyk.ey LÎ 
WMIseYaitursor False 


YirndaS tate Hoarrnal 


Text 
The tent associated with the control. 


إليك بعض الخاصيات التي تظهر في نافذة الخصائص فيما يخص الفورم. 


1 لتستخدم في الكود حيث‎ ۴٥۲٣ × هذه هي اسم الفورم»أو بدقة أكثر اسم الفئة التي تمتل هذه الفورم.یتم تسمیتها بشکل افتراضي‎ (Name) 
هو عدد ما.وقد يكون من المتطلب تغير هذا الاسم لشيء ما أكثر دلالة.‎ 


AutoScroll‏ إذا وض ضعت هذا الحقل إلى صواب»ءفإن النموذج يضيف بشكل آلي أشرطة تمرير والتي تتحرك حول محتوى الفورم إذا ما تم 
تحجيم الفورم لتصبح صغيرة جداً لإظهار كل شيء. 


Backgroundlmage‏ استخدم هذه الخاصية مع الخاصية ام رهام وة اله و)»ءة8لوضع صورة على خلفية الفورم. 


تسمح لك من إنشاء قائمة اختصار مخصصة تظهر عندما ينقر المستخدم يمين على خلفية الفورم.تشير مم u5‏ ntex×!Nه‏ إلى 


ContextMenuStrip 


EET ETE 


تضع صورة معروضة في الزاوية العلوية اليسارية لحدود الفورم. 


KeyPreview‏ إذا وضعتٽت هذه الخاصية لصواب»فان أحداث الفورم ey Press _„gKeyDown‏ »ستحصل ع معالجة أي مفتاح تم إدخاله من قبل 
N E‏ 
لكامل الف يبل اتتا الما إإااطلان ساعة عبر الاترت 


MainMenuStrip‏ تحدد أداة "عروة القائمةم نامه" "لاستخدام القائمة الرئيسية للفورم.يتم إضافة أداة عروة القائمة ما؛ئںمه» المشار إليها 
بشكل منفصل للنموذج. 


الشفافيةءتسمح بتخصيص مستوى الشفافية للون معين 


تشير إلى الحجم الحالي للفورم من خلال الخاصيات الفرعية العرض ماه¡ والارتفا عام وام . 
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Tag‏ بإمكانك وضع آي نوع بيانات تريدها في هذه الخاصيةءفهي موجودة لكي تستخدمها. 
لقد جدولت أقل من نصف الخاصيات هناءفمن الواضح أن لديك الكثير من التحكم على الفورم وكيفية إظهارها للمستخدم.ما يهم فعلياً 
هو أن العديد من هذه الخاصيات غير مقصورة علي النماذج.بعض من هذه الخاصيات تأتي من idة System.Windows.Forms.Control‏ 
المشتركةاة ںا" .وتظھر يا في كل الأدوات الأخرى التي تستخدم نفس الفئة القاعديةككهاء 48ط .و تتضمن هذه الخاصيات مثل 
الموضع ٣‏ ca†|0‌ها‏ »لون الخلفية۲هاه٤)عمع8‏ .والنص×۴٠‏ »على الرغم من أن النص المعروض في عنوان ١٥0|آأمهعالفورم‏ والنص ا×1€۴ 
المعروض على زر الأمر يختلفان بشكل ملحوظ في إيجادهم,فإن الاستخدام في الكود متطابق. 
ROEL He TRIS US @ ESEN CADE OM‏ 

BUEEORL . lex TIDES TS A DBUEEOD CAPELOM 
على الرغم من أنك تستطيع وضع كل الخاصيات من نافذة الخصائص»بإمكانك أيضاً تحديث وعرضها من خلال الكود.في الحقيقة»إذا ما‎ 
عدلت أي من الخاصيات من خلال نافذة الخصائص »فتكون قد حدتتهم خلال الكود المصدري»بما أن الفيجوال أستوديو يعمل على تحديث‎ 
كودك تماما دون تدخل منك.جرب هذا»ضع أي من الخاصيات في لوحة الخصائص للفورم ومن ثم اعرض الإجراء "التمهيد للمكونات‎ 
.تستطيع مثلا وضع الخاصية أكه ۷م١٠ إلى صواب»وستجد العبارة الجديدة التالية‎ ۶۴0/۳٠1. Dعئ/و”ع/.۷طفلم في‎ ""1nitiaاieComponent‎ 
قرب النهاية السفلية للإجراء.‎ 


ME: TOPDMOSIE E E 
بإمكانك عمل هذا من جانبك لتخصيص الخصائص من خلال الكود فما عليك سوى وضع الكائن متبوع بنقطة ومن الخاصية التي تريد كما‎ 
.۲0مM‎ 05 فعل الفيجوال أستوديو مع الخاصية‎ 
"ihe LIOEGEY EBEONSCEN 
بإمكانك أيضاً استخراج قيمة الخاصية من خلال أسماءها كما يلي:‎ 


Me. Text 


MEE)‏ & 4 لن ددا 
بإمكانك الوصول لطرق الفورم المتنوعة بنفس الطريقة.على سبيل المتال.الطريقة إغلاق التي تغلق الفورم: 
Me.Close ()‏ 
بالطبع هذه العبارة تحتاج أن تظهر ضمن إجراء ما محقق مثل معالج حدث ما e۲اh2d event‏ . لنضيف بعض الكود لحدث نقر ځn€ev Click‏ 
على الفورم لذلك عندما ينقر المستخدم على الفورم فإن الكود الجديد سيعمل على تبديل عنوان الفورم بحيث يذكرنا ما هو هذا 
العنوان » وإغلاق الفورم يؤدي إلى الخروج من البرنامج . للوصول 55ء۸ إلى الکود المصدري اختر ۴۵۲۸۳۱1.۷5 في مستكشف الحلول 


utionاS0‏ ومن تم انقر علی زر عرض الکود View Code‏ عند أعلی مستكشف الحلول . يظهر مقطع كود الفورم الافتراضي 


UMSTEBOS E 


BUOIMEe CLASS ESEN 


EMC CLES 

هذه هي الحصة المتنقلة لفئة الفورم .۴0٥۲٠١1‏ الجزء الذي تظهره الفيجوال استديو للعامة » وليس الأجزاء المخفية الأكثر أهمية ( الجزء 
في ۴0/771.285/9/78۲۰۷0) . ولكن سنكون قادرين على جعل هذا المقطع هام . أضف حدث نقر ٤۸عvع‏ )icا€لسطح‏ النموذج ۴0۲۳۶ 
surface‏ باختیار ( أُحداث الفورم ٤ve ns‏ ۴0۳1 )من قائمة اسم lلفئة Class Name‏ (أعلى ویسار محرر نص الکود )» ومن تم اختر نقر 


: ظھر فی الث التالى‎ los « Method Name ةقيıرط¦ط‎ | من القائمة المنسدلة لاسم‎ 
ل يطعر‎ 
0 WYindowsAÃApplicationl - Microsoft Yisual Studio گا‎ 8 *| 
File Edit Yim Project Build Debug Datla Tools Test Windom Help 
کن کے کے اک ل کک کے ی ھی ی کیا کے کی یک یک کی | ک8 ل کر کک ای اک اا ی کچھ ھن ا‎ 
| 1 lbox اک ا‎ Start Page’ Forml.¥bh" Forml.vb [Design [Î Modulel.wb | a ا‎ 
[5 General 0 
| # (Form Events] یه‎ | | #F Click | 2 
. 
There are na usable controls 1i Public Class Forml m7 
in this group. Drag ann item 2 Private Sub Form1 ClickIByVal sender As Object, ااا‎ 
anto this text to add it to the =1 
oolbok. BFVal 6© As System. EvetArGs] Handles MHe.Click 3 
3 aT 
3 End Sub ا‎ 
5 End CIass ّ 
fj = |B 
ا‎ 5 
3 
Ta 
ق‎ 
hS 
= 
MD 
2 
A 
| 
تخا‎ Fı, Toolbox || E Server Explorer | E اس‎ 
1 Error List) 
Ready L3 Col Ch1 INS 


عدل معالج الحدث بحيث يعرض الكود المبين هنا: 
System.EventArgs) Handles Me.Click‏ 


Private Sub Forml1 Click(ByVal sender As Object, ByVal e As 


ERA SUS 


رم سيظهر صندوق رسالة مع عنوان الفورم قبل الخروج من التطبيق لاحظ الشكل التالي. 


تتضمن الفيجوال بيسك والدوت نت الكثير من أدوات نماذج ویندوز وحتی يمکن عمل أدوات واستخدامها كالأدوات العادية الموفرة في 
صندوق الأدوات. بإمكانك بناء أدواتك الخاصة»ءإما باشتقاقها من فئات أدوات موجودة أو تنفيذهم بالكامل من الصفر. 


HE The Library Project 5 ك‎ - × 


YYindowsA pplication Î * 


The form's caption is: The Library Project 


موائی 


صندوق أدوات ×هطامه٣الفيجوال‏ أستوديو يتضمن جميع الأدوات الأساسية التي تحتاجها لبناء تطبيقات برمجية عالية النوعية -٣وا"‏ 
quality‏ 

أو حتى منخفضة النوعية ويإجحافرأاااةا- - سا theticهم‏ .للوصول إلى صندوق الأدوات-الجزء الذي يظهر في الشكل التالي-من خلال 
عرض ۷i۵W‏ >> صندوق الأدوات×هطامه۲ . 


Taolbox 


IE All Windows Forms "E 


ll Common Controls 1 


lk Pointer 
karl Ea 


Button 
Werslon A.0.0.Û fram Microsoft Corporation 
MET Component 


Raises an event when the user clicks it. 


LnkLabel 
ListBon 

Lista 
MaskedT extBox 
Month Lalendar 
2| Hoatiplcsar 


2 E 


IB IG 
II 


Û 


HuımericllpÛ oy 


E 


PicturgB on 


ProgressBar 


9| 


E Server Explorer 


يوجد أربع طرق لإضافة أداة لفورم: : 

1.النقر المزدوج على الأداة في صندوق الأدوات.فتظهر نسخة من الأداة على سطح الفورم في موقعها الافتراضي مع جميع الإعدادات 
الافتراضية. 

2. سحب وإسقاط الأداة من صندوق الأدوات ×٥طا۵ه۲إلی‏ الفورم ۴٥۲۳٣‏ . 
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3.انقر على الأداة في صندوق الأدوات»ومن ثم استخدم الماوس لسحب المنطقة المستطيلة على الفورم حيث ستظهر الأداة.بعض 
الأدوات»متل أداة الصندوق المركب×5080١۳ K0‏ .لديا حدود بالنسبة للعرض والارتفاع .فلییں من الضروري أن تحجم نفسها عند تنوي. 

4 .أضف أداة للفورم باستخدام الكود المصدري للفيجوال أستوديو. كما تضيف أدوات للفورم في الفيجوال أستوديو.فهي تکتب الكود 
المصدري لك.لايوجد سبب لعدم إضافة هذا الكود بنفسك»على الرغم من أنه يوجد تحذير في الملفط۷١/285/97€‏ .۶0/771 يخبرك بعدم 
تحديث هذا الملف»بإمكانك تعديل الإجراء كأ١8٣0م ٥0١‏ اهنا [بشكل يدوي إذا ما طابقت بدقة نمط الكود المولد بواسطة الفيجوال 
أستوديو.يإمكانك أيضاً إضافة أدوات في مناطق أخرى من كودك»مثل حدث تحميل الفورم.إضافة أدوات بشكل آلي يقع فيما وراء مجال 
هذا الكتاب»ولكن تابع وجرب هذا. 

بعض الأدوات لیس لدیها واجهة مستخدم حقيقية موجودة في التطبيق المشغل .هذه الأدوات»عند إضافتها للفورم تظهر فقي لوحة أسفل 
سطح الفورم. وتستطيع الاستمرار في التفاعل معها تماما مثل الأدوات المعتمدة على الفورم 

حالما تظهر الأداة على الفورم استخدم الماوس لنقل الأداة أو إعادة تحجيمها باستخدام المر Snot Ue‏ ) التي تظهر عند يتم 
اختيار الأداة.العديد من الأدوات ن تکون محدودة في خيار التحجيم.أداة الصندوق المركب×0080١0)‏ »على سبيل المثال»يمكن فقط إعادة 
تحجيمها أفقياً.وحجمها الشاقولي يتم تحديده بواسطة الأشياء مثل الخط f0١‏ المستخدم في الأداة.بينما تسمح لك أدوات أخرى إعادة 
تحجيمها.ولكن فقط في بعض الأحيان ان داق الرقعة(اللصاقةاع اها )يمكن تحجيمها يدوياً عندما تكون خاصيتها عizكهاا۸قد‏ تم وضعها إلى 
خطاً ۴€ فقط. 

تتضمن بعض الأدوات زر سهم صغيرء ويظهر على الأغلب قرب الزاوية العلوية اليمينية من الأداة.وهو عبارة عن بطاقة(اقتباس 

سريع 9ة 53۲)» مشابه لميزة الاقتباس السريع المضمنة في ميكروسوفت أوفيس.يوفر النقر على الاقتباس السريع الوصول السريع 
إلى الميزات المصاحبة للأداة .كما هو مبين في الشكل التالي. 


Hl Farm] 


ComboBox Tasks‏ اپ 
amara 5 LIze data bound itera‏ 


Unbound Mode 
Edit lbernz 


تبين القائمة التالية بعض الأدوات الشائعة الأكثر استخداما »وکلها مضمنة بشکل افتراضي مع تطبیق نماذج ویندوز ۴0۲۳۶ d0۷WsہWi‏ 
application‏ وبشکكل افتراضي في صندوق الأدوات×ه‌طامه . إذا ما انشئت تطبيق نماذج انترنت ١5‏ 10اةءأاممة dعsهط-طعسفي‏ الفيجوال 
أستوديو-المستخدم لتصميم تطبيقات معتمدة على الویب باستخدام ۸5۴۶.۸۴۲ -فإن الأدوات المتاحة ستختلف عن هذه القائمة. 


Background Worker 3‏ تتضمن الدوت نت دعم للتطبيقات ذات مسارات التنفيذ المتعددة لهلهم ٠۲١1ا‏ .تتيح لك الأداة 

Background Worker‏ البدء بمهمة الخلفية )وها ٣d‏ uتءو)عهطتماما‏ من الوضعية المريحة لنموذجك.وهي 
مفيدة بشكل خاص عندما ترغب في تحدیث فورم بالاعتماد ع عرض العناصر المتفاعلة مع مسارات 

تنفيذ ”٣ع‏ )إمس“ أخرى.إنك تستأنف مهمة عمل جديدة من خلال طريقة الأداة > رAs Ru” N۷0)‏ »وتنجز العمل 
الحقيقي في حدثها )0۲ .D0W‏ 


CheckBox‏ تنفذ هذه الأداة طريقتين(فعالمه »غير فعال؟ه )أو ثلاث طرق(فعال مه »غير فعال؟؟م ءأخر ٣اه‏ ) لحقل 
اکر کا موہ ۹ کس اتا واے وم ال اه الک دن الار ات اع الاه 
"مختبر ل )مط " من لل dEEBOES‏ صناديق الاختبار ذات الطريقتين »أو الخاصية ءاه†S)ءمC‏ من 5 


إن الا دات ف رن 


ا 


ColorDialog‏ تعرض نموذج ويندوز قياسي مستخدم لاختيار لون من قبل المستخدم. عرض حوار اللون باستخدام طريقة الأداة 


واةDi Show‏ »و تحصل على النتيجة بواسطة الخاصية ۲ماه٤.‏ 


ContextMenuStrip‏ هذه الأداة ة تتيح لك لك تصميم اختصار أو قائمة ائمة"سياق†contex‏ "بلتم عرضها عندما ينقر المستخدم يمين یمین 
على الفورم أو أداة تختارها أنت.ويتم تصميمها واستخدامها في الكثير من الشبه كما هو الحال ا 
س ا 
DateTimePicker‏ تتيح هذه الأداة للمستخدم إدخال تاريخءوقت أو كلاهماءمن خلال إما مدخلة النص الأساسية أو الأدوات 


المعتمدة على الماوس. على الرغم من أنه نموذج غیر حر کحقل اللص البسيطءفهو يعمل ل إجبار 
اختیار لتاريخ ما أو وقت ما.بإمكانك وضع النهايات العظمى والصغرى على اختيار المستخدم.توفر الأداة 
onth Calendar‏ و اجھة بدیلة لاختیار تاریخ مخصص. 


FolderBrowserDialog‏ تعرض نموذج ویندوز القياسي المستخدم من أجل اختیار دلیل ا و مجلد من قبل المستخدم .تعرض صندوق حوار الاختيار 
باستخدام طريقة ShowDialogsls!‏ »والحصول على النتيجة باستخدام اlıخاصة .SelectedPath‏ 


توفر طريقة ة بسيطة لتجميع الأدوات بشكل مرئي على الفورم.الأدوات التابعة يتم رسمها أو لصقها مباشرة على هذه الأداة. 
للوصول إلى نفس التخصص الوظيفي بدون حدود مرئية أو عنوان استخدم الأداةامم ج۴ . 


GroupBox 


لأداة شريط التمرير الأفقيءبحيث تسمح للمستخدم من التمرير خلال قطاع العرض أو قائمة من الاختيارات.من أجل 
الشاقولي لهذه الأداةءاستخدم الأداةه ۷50١١8‏ .تتضمن العديد من الأدوات الأخرى نسخة خاصة بها لأشرطة التمرير 


تعرض هذه الأداة نص ثابت على الفورم.وتستطيع رسم خطوط مستطيلات وما إلى ذلك. 


HScrollBar 


ListBox‏ تنفذ هذه الأداة أداة صندوق نص قياسي»عارضة قائمة من البنود بحيث يستطيع المستخدم اختيار ما يشاء.يمكن للبنود المضمنة 
أن تكون أي كائن ترغب»فهي ليست محدودة لنصوص فقط.وتستطيع توفير كود حامل رسم 0۷۸6۲۵۲4۷ يسمح لك رسم كل 


MaskedTextBox‏ تنوع عن صندوق النص القياسي يساعد المستخدم على إدخال عدد منسق أو بيانات نصية بعرض قالب أو قناع»على سبيل 
المثال تستطيع إجبار المستخدم على إدخال رقم الهاتف في هيئة"×××-× ×× ×××" باستخدام القناع العددي مع تضمين رموز 
الشحطة أو الواصلة القصيرة. 


MonthCalendar‏ تعرض مجموعة جزئية من التقويم»مركزة العرض على العرض الخاص بالشهر.يمكن أن يتم عرض أكثر من شهر في نفس 
الوقت.في تركيب شاقولي »أفقي»أو في تركيب شبكة.توفر الأداة )ء۴ ٠‏ "٣ه‏ 0واجهة بديلة من أجل الاختيار الخاص 
بالتاريخ. 


تسمح للمستخدم من اختيار قيم عددية باستخدام طريقة مقطع أعلى/أسفل القابل للتمرير.استخدم هذه الأداة كبديل عن الأدوات 
«TextBox «‘HScrollBar‏ rrackBar؛‏ أو Serr‏ عندما يكون هناك مسوغ. 


NumericUpDown 


PageSetupDialog‏ تعرض نموذج ويندوز قياسي يتم استخدامه لتركيب صفحة الطباعة بواسطة المستخدم.تعرض صندوق حوار الاختيار بواسطة 
طريقة الأداةوماهİاسهطS‏ »تحصل على النتيجة بواسطة الخاصية ءوہاSeمPagوlاlخlاصية .PrinterSettings‏ 


PictureBox‏ تعرض هذه الأداة صورة بهيئات متنوعة. 


PrintDocument‏ یتم استخدام هذه الأداة كجزء من عمليات معاينة الطباعة والطباعة.فهي تضيف دثار حول تنفيذ الطباعة الخاصة بك»موفرة 


ProgressBar‏ يوفر تغذية راجعة رسومية للمستخدم من أجل مجال إتمام مهمة. عادةٌءيكون المجال بين 0 %و0100»ءولكن تستطيع توفير 
مجال مخصص.تشير الخاصية مںاج۷للاإعدادات الحالية بين حدود المجال الأدنى ص ص امہ۷1 والأعلى „Maximum‏ 


RadioButton‏ تنفذ هذه الأداة زر اختیار تبدیل 010ھ م‌ویندوز قياسي. على الرغم من عرض نقطة دائرية أكثر شيوعاء»يمكن أن تظهر الأداة 
أيضا كزر مفصلي ۸ 0اط هاووه)بوضع الخاصية ه٨"‏ 2۲4هممم۸بشكل مناسب.تشير الخاصية )ه۸ إلى القيمة 
الحالية للأداة.جميع أدوات زر التبديل اا8 هله التي تظهر ضمن نفس "سياق المجمو عة×ها/ gp ٥0‏ " تتصرف 
بأسلوب خاص مشترك»استخدم الأدوات اعمج ۴ر ×80مںملإنشاء سياقات لمجموعة معينة. 


SaveFileDialog‏ تعرض هذه الأداة نموذج ويندوز قياسي يتم استخدامه لاختيار حفظ ۷هو ملف من قبل المستخدم.يمكن للمستخدم من أن يختار 
ملف جديد أو موجود من أنظمة الملفات المحلية أو البعيدة.وتطلب هذه الأداة من المستخدم بشكل اختياري من معاينة الملفات 
الموجودة. عرض صندوق حوار الاختيار باستخدام الطريقة Dial‏ Show»والحصول‏ على النتيجة بواسطة الخاصية 

Name‏ eا۴.توفر‏ الطريقة ١ا۸۴هم0طريقة‏ سريعة لفتح الملف المختار. 


StatusStrip‏ تعرض هذه الأداة شريط الحالة ةط وuاهاء‏ »عادة على طول الحافة الدنيا من فورمك»من خلالها تستطيع عرض حالة 
»ومعلومات حساسة بالسياق أخرى للمستخدم.يمكن للشريط من أن يحتوي عدة أدوات أشرطة تقدم82ءءه وم٥‏ ٬لوحة‏ شريط 


حالخStatusStripPanel‏ »و أداة عنوان شریط أدرات|eطھ۔مStri|ھoا‏ . 


تنفذ هذه الأداة صندوق نص ويندوز قياسيءفي نمط وحيد السطر ٣٥‏ ام‌اوہ‌اء ومتعدد الأسطر ٣٥‏ اناا" .محتوى الجسم 
الرئيسي هو مجموعة على طول خاصية النص×ه] . تسمح لك الخاصيات 0۲0٥12۲‏ ۴asswو‏ 
Char‏ seSystemPasswordل‏ من تقنيع المدخلات عندما يعمل المستخدم على كتابة كلمة المرور. 


ToolStrip :BE‏ تنفذ هذه الأداة شريط أدراتهطامه تظهر عليه أدوات أخرى.وتأتي مع مجموعة أدوات مرافقة وفئات توفر معالجة وميزات 


تفاعل المستخدم متقدمة. 


ToolTip‏ تتيح لك هذه الأداة تحديد "تلميح أداةمن اوها "من أجل الأدوات الأخرى على الفورم. عند استخدامهاءفهي تضيف شبه خاصية 
"تلميح أداةم أ امه " لكل أدوات الفورم الأخرىءمن خلالها تستطيع تزويد نص تلميح الأداة المرافق.عندما تحوم الفارة فوق 
أداة يظهر نص التلميح المرافق»ءوذلك من خلال ظهور نافذة نص صغيرة بشكل مؤقت فوق الأداة لتوفير معلومات مفيدة 
اا 

م. 


ا TreeView‏ تجلب هذه الأداة مجموعة بنود في ترتيب هرمي.وهي مشابهة تماما إلى قسم"شجرة الأدلةه هع إاها ها " لمستكشف 
ملفات ويندوز أو فيستا.كل بند في الشجرة هو عقدة مله" يمكن أن يكون لديها صفر عقدة أو عقد أبناء أكثر. 
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WebBrowser [EF‏ تنفذ مستعرض ويب ضمن تطبيقك.تستطيع استخدام ميزات بحث معتمدة على ويب قياسي متاحة ضمن مستكشف الانترنت 
|nternet Explorer‏ من أجل الوصول المعتمد على عناوین الانترنت 81ل »أو توفیر محتوى _ 1۲۷ مخصص خاص بك 
من خلال الخاصية gÎDocumentText‏ الخاصيات ذات الصلة. 


کل نموذج واداة في الدوت نت تحتوي على إجراء ويندو "۵۴۲٥٥‏ ۷الخاص بهاءوكما أنها تعالج الرسالة الواردة من مضخة الرسائل»وتترحم 
هذه الرسائل إلى نحد|eyventsi‏ .إن الأحدات اهي تقنية دوت نت القياسية التي تتحكم-وجميع الفئات الأخرى-باستخدام كل 


من الفورم والأدوات .فعندما تضمن فورم أو أداة فقي تطبيقك »تستطيع عرض واحد. أو بعض :أو كل هذه الأحداثءوكتابة الكود الذي 
يستجيب بشكل مناسب. كل الكود المخصص الذي تكتبه لكل حدث يظهر في معالج الحدث/ءع/۸2/0 ٠۷e”‏ .ولكن ما الذي يحدث فعليا 


بين إصبع المستخدم على الماوس والمنطق في معالج حدث مخصص؟.يبين الشكل التالي بشكل بياني ما يحث عملياً بين 
الإحراء(الفعل) والمنطق المخصص. 


يتم تشغيل معالج الحدث الإ ستجابة تحدث ستازالسحر 


Friwate Sub Butonl _ClickBy'yal sender As 
System. bject, ByYal e As System.EventArgs; 
Handles Buttonl Click 


بتار المستم على زر 


4 Buttonl Ê 


بم وضسج اليد جنا 
End Sub‏ 


من الواضح »أنه مایزال بعض الغموض ٣۷۶۴۲۷‏ محیط بمعالج الحدث.الأدوات كاه٣‏ ا٣0٤‏ -وكل الفئاتءعءءهاء - تحدد أي الأحداث ستجعل 
منها متاحة.فمن أجل الأدوات يتم إتاحة العديد من الأحداثت بالتوازي مع إجراءات المستخدم الأولية :lلüiكقرClick‏ »الماوس للأسفل 
MouseDown.>ۈhé KeyPresse lie‏ .والحجم تغيرل٥ 512٤۸3١9‏ .ولكن يوجد أيضاً العديد من الأحداث يمكن أن يتم إطلاقها فقط من 
خلال التعديلات على الأداة خلال الكود المصدري: ١ع۳۸3/9٤×ع ٠51"4‏ (عندما يتم تغير ترتيب مفتاح التنقل إع)-طها للأدوات)ء 
BackgroundImageChanged‏ و ursorchanged‏ هي فقط ثلاث من العديد من الأحداث التي لايمكن للمستخدم أن يؤثر عليها بشكل 
مباشر.العديد من الأحداث الأخيرة ترتبط بالتغيرات على مستوى النظام كعمو ه۸ ام۷عا-٣عاكرء»‏ مثل الحدث 
orsCchangedاSystemCo.والذي‏ يتم إطلاقه عندما يعدل المستخدم جدولة الألوان الواسعة Jلنظ|م system-wide COIOr SCheme‏ منi‏ 
خلال لوحة llتحpanelpS control‏ . 
EI vete SUS BUEEOML CIIEK (EMEL SEMIEE AS SOCEM OEE, ENEAl @ AS SVEN, BNMORLATEOS)‏ 
Handles BUCEODNI EIEN‏ 


ERG SUS 
( senderلسرملا(ةلاح‎ Syءtع”.0اطزعءا:هقالطإ يستقبل معالج الحدث هذا معاملين نسبيين كأ١€١۲91ةمن حدث تم‎ 
نسخة (حالة € )» معالجات أحدات أخرى يمكن أن تستخدم معاملات نسبية مختلفة قليلاًلذلك كيف تعرف ما‎ System .EventArْئsو‎ 
تستخدم؟إن أي حدث معرف ضمن فئة أداة يجب أن يشير أيضاً إلى عدد ونوع المعاملات النسبية التي يرسلها إلى معالج‎ 
الحدث.تتضمن الفيجوال بيسك العبارة ٣۷ع التي تعرف الأحداث.مع أن وعلى الأرجح أنه تم كتابة الزر في السي شارب#C ءإليك ما‎ 
يبدو عليه تعريف حدث لحدث نقر الزر في الفيجوال بيسك:‎ 

Public Event Click (ByVal sender As System.Object, ByVal e As System.EventArgs) 

هذا التعریف يبدو مشابه کثيراً لمعالج الحدث السابق(5ط51 2اة۷آ۴۲). وهو كذلك.تؤسس العبارة أ١٣۴۷6عقد(اتفاقية)تمرير‏ وسيط 
jı parameter- passing contract‏ الأداة والكود الذي يريد أن یستقبل إشعارات(بیانات) الحدث .event noاiifاcھاا0٥ ٣5‏ في ھذە 
الحالة»حدث النقر يعد كعكأصه۲مأن يرسل معاملین. نسبيين إلى معالج الحدث.الأول هو المرسل56۸06۲ »وهو مرجع(دليل 
عreferenc)للكائن‏ الذي يشير إليه الحدت.من أجل أدوات الزرءاه٣†”هc Button‏ » هذا الوسيط يستقبل مؤشر لنسخة(حالة )الزر 
نفسه.المعامل النسبي الثاني» €»يوفر طريقة لتمرير كائن كامل المعلومات الإضافية.إن الفئة 5۷56١١.۴۷8۸۲۸۲۵5‏ ليس لديها الكثير من 
المعلومات»ولكن بعض الأحداثت تستخدم تنوع ما في المعامل النسبي الثاني الذي یستخدم ۸۸۲95 ۴۷۵."عاكر5 كفئة قاعدية له. 
هذا يكشف أن المعاملات النسبية المستخدمة لحدث النقر هي مشتركة إلى حدما بين الأدوات والأحداث المختلفة.فعوضاً ٠‏ إعادة 
كتابة قائمة المعاملات النسبية في كل عبارة حدٿ»يمکن لمصمم الأداة أن يعرف تفويض ماعاةو٥/46‏ :نوع ما للدوت نت يعمل على 
تعريف قائمة معاملات نسبية»أما من أجل الدالات قيمة راجعة. 


Public Delegate Sub StandardEventDelegate (ByVal sender As System. Object, ByVal e As System.EventArgs) 

يمكن لعبارات الحدث فيما بعد استخدام تفويض معرف كاختصار لقائمة الوسيطات الكاملة المكتوبة. 
Public Event Click As StandardEventDelegate‏ 

سواء كان الحدث يستخدم تفويض أو قائمة المعاملات النسبية الكاملةفله سيطرة تامة 9۲۵5۲ ۴۲۳ على ما يحتاج أن يرسله من بيانات 
إلى أي معالج حدث مستقبل .وإنه يرسل هذه المعاملات النسبية باستخدام عبارة الفيجوال بيسك ۸۵56٤۷8١‏ .دعنا نقتفي أثر هذه 
المعالجة من أجل أداة الزر.عندما ينقر ا الزرء تعمل مضخة الرسائل ۷۳م "٠55298‏ على إيجاد طريقة لترسل رسالة 
إلى إحراء ١۴۲٠١٤‏ ۷الخاص بأداة الزر.وإن ذلك الزر يتفحص الرسالة» ويرى أنها نقر بالماوس ويقرر أن يخبر معالج الحدث event handlers‏ 
حولها. ومن تم من ضمن كودعه۷"۵۴۲ .يعمل على إطلاق الحدت. 
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RaiseEvent Click (Me, New System.EventArgs) 
تشير كلمة الفيجوال بيسك المحجوزة 1۵ إلى حالة(نسخة)أداة الزر نفسها.لايحتوي المعامل النسبي ع لأداة الزر أبعد من الحقول‎ 
۷فقط يرسل حالة(نسخة) فارغة جديدة.الأدوات ذات‎ "۴۲٥٤١ .لذلك فإن‎ System.EventArgs (ةJlخÈ)ةخسن الافتراضية المضمنة في‎ 
حدث مع معاملات نسبية أخرى سيكون قد أنشئ حالة أولآًءيملأها بالبيانات المتعلقة»ويمرر تلك النسخة إلى معالج الحدث.إذا ما أطلق‎ 
حدث في تطبيق»ولم يكن هناك معالج حدث يسمعه»هل يعمل صوت؟من المحتمل لا.لايوحد متطلبات لأن يكون لحدث ما معالجات فعالة‎ 
مستقبلة(منصتة).ولكن عندما نريد أن نهتم بحدث» كيف نفعل هذا؟الطريقة القياسية لعمل هذا‎ 
ادر )أن يعلن عن أداةء بمعنى"أريد أن أعرض أحداثك(أي أن الفورم‎ fn .الأولىءيحتاج مستخدم الأداة(فنة فورمكءءهاء‎ 8 


ستعرض أحداث الأداة الموضوعة على سطحها)"ومن ثم توصل معالجات الأحداث بأحدات خاصة.سابقاً في هذا الفصلءرأينا أن إضافة 
أداة إلى واجهة المستخدم يحث عملياً على كتابة كود مصدري عل0» ع۲ ا0ء في الملفط۷ ١9.78€۲/ئع2‏ .۴0/771 . إليك الكود الذي يتم 


إضافته من أجل أداة زر مسماة 1١0(الا8(مع‏ أرقام الأسط. 


UL BEETLE CLASS ROA 

02 Inherits System.Windows.Forms.Form 

03 

04 Friend WithEvents Buttonl As System.Windows.Forms. Button 
05 

06 BElva te SUDO INIEIalIzZeECOMPOnNeNEK |) 

07 Me.Buttonl = New System.Windows.Forms. Button 

08 

09 Me.Buttonl.Location = New System. Drawing. Point (48, 16) 
10 Me.Buttonl1l.Name = "Button1l" 

11 Me.Buttonl.Size = New System. Drawing.Size (75, 23) 

12 Me.Buttonl.TabIndex = 0 

l3 ME. BUCEONL. TexXE  "BUEBONIUT 

14 Me.Buttonl.UseVisualStyleBackColor = True 

5 

16 Me.Controls.Add (Me. Button1l) 

LJ ENG Sub 

lS Endl CLeSS 


الكود في الطريقة خ١€١‏ 0م١۳‏ 0٥٤ع7ااةناأ٣آيعمل‏ على إنشاء حالة لأداة الزر(السطر7).»يعمل على تعديل خاصياته للحصول على المظهر 
الذي نريد(السطر9 إلى السطر14)ءيلحقه بالفورم من خلال السطر16.ولكن يوجد سطر واحد إضافي يعمل على تعريف حقيقة الزر كنوع 


: (السطر4)‎ reference type variable لمتغير مرجعري‎ 
Friend WithEvents Buttonl As System.Windows. Forms. Button 


سنتحدث فيما بعد عن الحقول على مستوى الفئة كلاعا؟ ام۷عا-ءءهاء.والزر 1١0الا8هو‏ حقل نموذجي على مستوى الفئة.ولكن 
الكلمة المحجوزة كأ ع۷٤۸‏ iل۷المضمنة‏ في العبارة هي ما تتيح للأداة معرفة أن أحدما يريد عرض إشعارات الحدث.الآن »في أي وقت 
ینطلق حدث الزر. فانه یعرف أنه یمکن للفورم ۴٥۲۳1‏ أن تحتوي على معالجات حدث تراقب وتھتم(تستقبlisteningJ watching and‏ (. 
:تتضمن عملية الوصل بين الحدث والمعالج event -to-handاer connection process‏ الربط الحقيقي 
للمعالج).لننظر مرة أخرى على تعريف معالج حدث النقر €۲ال۸27 Click event‏ لنسخة lلزرButton1‏ . 
Eri vate SUD BUEEORNl ClIEEKEVUSN Sender AS SVSEEM ON CCE, BYVUAl € AS CVSECM. EVEN AES) Handles‏ 
BEES CIE‏ 


End SUS 


فهي مجرد طريقة فئة عادية»ولكن مع الشرط كع ال١‏ ة1 المعلق في نهاية التعريف.هذا التعبير هو مايريط معالج الحدث event handler‏ 
مچ حدث icا€.1١0ااBu‏ نفسه.تستطيع إتباع الكلمة المحجوزة كعال٣ة١٣بعدة‏ أسماء أحداث. 
Eva Eê SUS BELO CITE EVAN Sender AS SVS ODN COE BEVIN E AS SVSEOME E VENE AESS) HERG les‏ 


BUE ESRI CITCEKE, BUEEONZ CUNEK, BUEEONSCLIEGK 


ERS SUS 
الآنءسيستمع معالج حدث مفرد لنقر عدة أزرار من عدة أدوات مختلفة.بإمكانك حتى مزج الأحدات المعروضة»فيمكن لمعالج حدث واحد‎ 
أن يستمع لأحداث مسماة مختلفة.‎ 
Private Sub ManyEvents (ByVal sender As System.Object, ByVal e As System.EventArgs) 
Handles Button1.MouseDown, Button2.MouseUp 
End Sub ٤ 
تنوع آخر هو أن يكون لمعالجات حدث متعددة عرض حدث مفرد»على الرغم من أن على الفيجوال بيسك أن تقرر استدعاء أي معالج أولاً‎ 
Private Sub FirstHandler (ByVal sender As System.Object, ByVal e As System.EventArgs) Handles 
Bulle ORI CITE 
ERA SUS 


Private Sub SecondHandler (ByVal sender As System.Object, ByVal e As System.EventArgs) Handles 
BUEEORI CIE 
End SUS 
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يوجحد طريقة أخرى لوصل أحداث كاأ١ع۷عبمعالجات‏ أحداث ك۲عال٣ة! event‏ والتي لاتتضمن سواء الكلمة المحجjaة WithEvents‏ İو‏ 
الكلمة المحجوزةءءا١”‏ ة١‏ .وهذا ما يتيح لك السيطرة على ترتيب المعالجة لعدة معالجات حدث.حالما يكون لديك حالة لفئة تعرض حدث 
class‏ exposing-event.فإنك‏ تربط معالج إلى واحد من أحداثه باستخدام العبارة۲ ۸40۳۸3٣018‏ .العبارة التالية تربط حدث نقر الزر 
8utton1بمعالج‏ حدث مسمیى۴ال M۷13٣‏ .يجب أن يكون للطريقة 6۲ال٣1۷13‏ قائمة معاملات نسبية محققة من أجل تعريف الحدث. 
AddHandler Button1.Click, AddressOf MyHandler‏ 
تزيل العبارة المخصصة ثRemoveHandleاتصال‏ معالج حدث بحدٿ ما. 
سنمضي الكثير من الوقت في كتابة معالجات الأحداث .ولكنني سأدخل أيضاً ضمن جميع التفاصيل بحيث تستطيع أخذ فوائد جمة عن 
هذه التقنية.فلا تسمح لك الفيجوال بيسك من عرض الأحداث الخاصة بالأدوات فقط ولكن أيضاً تتيح لك تصميم أحداث جديدة في فئاتك 
الخاصة.بإمكانك استخدام الكلمات المحجوزة ع ا2وءاء0 أو AddHandler. Handles. WithEvents.RaiseEvent «Event‏ « 
.NRemoveHandler‏ من أجل أحداثك المخصصة.» والتي يتم إطلاقها بواسطة شروط ما تختارها أنت.فإذا كان لديك فئة تمثل موظف 
oyeeاemp.بإمكانك‏ جعلها تطلق حدث"الطرد ۴|۲۴۵ " عندما يفقد الموظف عمله.يإضافة أحداث خاصة» فإنك تجعل من الممكن لكود 
خاص من أن يتم وصله بمنطق فنتك»أوه!ا ها .او حتى ولو لم يكن لمبرمج ما صلاحية الدخول للكود المصدري التابع لفئتك. 


إن أي نموذج تعمل على تعريفه ككائن بدء لمشروعك يظهر بشكل آلي عندما يبدأ البرنامج.أما بقية النماذج الأخرى فتحتاج لعرضها 
بشكل يدوي باستخدام إما الطريقة "إظهار »ه5 "أو الطريقة"إظهار حوار وهاةiا© 50W‏ " لتلك الفورم.مثلاًءإذا كان لديك فورم تدعى 
۴۳2 تستطیع عرضها باستخدام الطريقة 5۸10۷ : 

Form2.Show() 


تعرض الطريقة 5۸0۷ نموذج غير نمطي ۲0/7 كئع/770206/ .النماذج غير النمطية يمكن الوصول إليها بشكل مستقل عن جميع الفورمات 
الأخرى في التطبيق إالمشغل.ويمكن لكل الفورمات الغير نمطية أن يتم تفعيلها في أي وقت بالنقر عليها فقط والفورم التي تنقر عليها 
ستأتي إلى الواجهة أمام جميع الفورمات الأخرى وستستقبل ترکیز الإدخالوںعه؟ i "put‏ .یمکن لبرنامج أن یکون له واحد.أو اثنان أو 
حتى الكثير من النماذج الغير نمطية تفتح في نفس الوقت»ويمكن للمستخدم أن يتنقل بينها بكل حرية. 

النماذج النمطية |0١٣5‏ /۸1002 تتحكم بجميع الإدخالات في التطبيق»طالما أنها تظهر على الشاشة.والنماذج النمطية تدعى 
عادة"بالحواراتءوه اهال ".فعلى المستخدم أن يكمل النموذج النمطي ويغلقه قبل أن يتمكن من الوصول لفتح أي نموذج آخر في 
التطبيق.فنافذة صندوق الرسالة التي تظهر عندما تستخدم الدالة ×980ء۷اهي نافذة حوار نمطية. تعرض الطريقة وه٥اةا510۷W2نماذج‏ 
نمطيةءوتتيح لك العودة بقيمة من تلك الفورم.والقيمة المعادة هي Îعضlء‏ |lعslı .System.Windows.Forms.DialogResult‏ 


لعرض نموذج نمطي استخدم طريقة الفورم 5۸0۷513109 وبشكل اختياري التقط قيمتها المعادة. 
Dim theResult As DialogResult‏ 
theResult = Form2.ShowDialog ()‏ 


الحوارات النمطية كوهاهاك اةكه" مفيدة لتحديث سجل ما يتطلب نقر على زر موافق >0عند اكتمال التغييرات .لنقول أنك كنت تكتب 
تطبيق يعرض قائمة كتب ألكسندر دامس.من المحتمل أن يتضمن نموذجين‌©1)النموذج الرئيسي الذي يعرض قائمة الكتب.(2)النموذج 
الثانوي(الابن)والذي يتيح لك كتابة اسم كتاب مفرد. ألن يكون من العظيم إذا استطعت العودة باسم الكتاب(أو ريماء بالرقم المعرف 10 
لسجل ما خاص بالكتاب كما تم تخزينه في قاعدة البيانات)بدلاً من قيمة نتيجة |لlazرDialogResult‏ . 

إذا كانت الطريقةوهاةا2 50W‏ .طريقة عامة ١٥۸0ع"‏ اطلام لفئة فورم مضمنة»تستطيع العودة بنتيجة كود»من المحتمل أننا نستطيع 
إضافة طرق عامة أخرى للنموذج تعود بنتيجة كود بحيث يكون لديها معنى حقيقي. في الواقع»نستطيع ذلك.خذ الفورم الابن(المسمى 
00K Entry‏ B)مع‏ حقل البيانات المدخلة(عنوان الكتاب B00) ¡|e‏ )»ء والأزرار )ActOK)‏ )0و )اActCance)‏ اCance.‏ كما هو مبین في الشکل 
التالي. 


Dumas Book Entry 


Bonk Title: 


OKs) Caneel) 


عندما ندعمه بالكود التالي»هذا الفورم البسيط يعود بما تم كتابته في الحقل عندما ينقر المستخدم على زر موافق(في البداية يرفض 
القيم الفارغة)أو يعود بنص فارغ عند النقر على إلغاء ا6٤/8٥‏ . 
BEDISE CLASS BOSKEMET Vi‏ 
Buble Kuncl ion EQIELSEle() AS SEEING‏ 
Show the form, and return what the user enters.‏ ا 


u ME Show DnNa oS O) E Dia logRESU E OD MOE 
Return BookTitle.Text. Trim 

Else 
Re EUE 

e 


O OEE A O 
Ewa Sully ACECENEONL CLEC EVIL SECO 4S SMSEEN  OOECE, EME @ #M SMSC ONES) MEMOS 
KetCanecel CIek 
ڪڪ کک‎ Return a blank tEItle EOE Caneel 
Me.DialogResult = DialogResult.Cancel 
ص ا‎ Continue with EditTitle( ) 
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BENd SUS 


Eriva ee SUS AEOLOR CICK (EVN SENIEE AS SMSEEM ONE, Bal € AS SYSEOM EVUENEAEIS) HSRIleES 
ACEO E ek 
کے کک ت‎ ORLY aceeDt Valid Elles. 
If (Len (BookTitle.Text.Trim) = 0) Then 
MSGBOxX (IBPlêase Supply a Valid Elle. ") 
Else 
Me.DialogResult = DialogResult.OK 
ص ا‎ COMER Ue WIEN Ede Ele J 


el CIES 
لاستخدام هذه الفورم تستدعي الفورم الرئيسي الطريقةء|)آ أ۴ . والتي تعود بعنوان الكتاب المدخل من قبل المستخدم.‎ 
Dim mew Ele AS SEFIDNS > BOOKHDNEEY EAI EL EINE () 
من خلال الطريقة وهاةا(510۷Wءوينتظر هناك فقط حتى يغلق المستخدم‎ ۴٥۲۳١ "ه۵١ة2اال یعرض الروتین ۵|آ ۲اا الفورم بشكل نمطي‎ 
الفورم.إغلاق الفورم يتم من خلال الزر موافق أو الزر إلغاء»وإعداد خاصية ااuاكعR۸وهاه0iللفورم لديه تاثير جانبي على إغلاق الفورم.‎ 
»والذي يعمل تفحص سريع قبل العودة بالقيمة النهائية.ويالتالي نحصل‎ Edit Tiاع حالما يتم إغلاق الفورمٍ يتم إرجاع تنفيذ إلى‎ 
:واجهة عامة جديدة من أجل قيمة النماذج المعادة الأكثر أهمية.سنستخدم هذه الطريقة كثيراً في تطبيق مشروع المكتبة.‎ 


كود مشروع هذا الفصل ينفذ الفورم الرئيسي الأساسي ۷31١‏ لمشروع المكتبة. بالإضافة إلى الفورم" 5۸ةام5 "التي تظهر عندما 
یشتغل المشروع للمرة الأولى .تعرق میکروسوفت أن هذه كانت حاجة مشتركة» متضمنة دعم لکل من الفورمات الرئيسية والمنتشرة 
في نظام إطار عمل تطبيق الفيجوال بيسك. بشكل افتراضي»هذا النظام يتم تمكينه من خلال صفحات خاصيات المشروع(شاهد 


WindowsApplicationl ° Form1.4b [Design] [ Start Page | 
Application 
> اف‎ ûssembly name: Root namespace: 
ا‎ Compile [wîndowsêpplication1 | WY indomsÃû.pplicatiorı1 

Debug Application type: lcar: 
| indonms Forms Applizatiorn ی‎ | [Cefault Icon] ی‎ mm 

References 
Startup form: 

Resources | Form ا‎ | 

| Services | Assembly Information... أ‎ [ Wey AC Settings 
Seine Enable application framewyork. 
Signing 


windows application framework properties 


My Esl Enable #P visual styles 
Security [Ll] Make single instance application 


Save My. Settings on Shutdown 


Publish 0 
Authentication mode: 


Ss. 2 [windows اه‎ 
Shutdown mode: 
| whan startup form closes e 


Splash screen: 
Rone! 


[ Wie Application E vents 1 


تشير حقول"فورم الانطلاق ۴٥۲٣‏ مهك " والنافذة"المنتشرة١۴عء۲۴ءء‏ كةامS‏ " إلى الفورم الرئيسي ١ة"‏ و المنتشر١كةامء‏ على 
الترتيب .فهذا سریع» »وسهل »وهو مجر شيء معد للاستخدام لذلك لندخل فقي العمل. 
يكون الآن وقت عظيم لتحميل | البادئ لاف السابع. 


لقد عملت على إضافة ملف فورم جديد للمشروع»مسمى ۷5 Splash.‏ (أي آن الفورم نفسه مسمى ١5هام5)»متضمناً‏ بعض العناصر 
المعروضة.تحرى عن الصورة على الفورم.يتم جلبها من خلال أداة"صندوق الصورة ×0 ۲۴8١ء۴‏ "»ولكن تم تخزينها في التطبيق كمصدر 
0urceكre.‏ يتم إلحاق مجموعة من السلاسل الحرفية كو”١‏ |۲ أكوالصور كعوه"الكودك المصدري.يتضمن مجلد المصادر كع//501٤۸في‏ 
مستکشف الحلول ملف هذه الصور. .ويتم وصله ضمن صندوق الصورة من خلال خاصية mage]للأداة.‏ . ومن المؤكد أنها تجعل الفورم ذات 
مظهر جيد.عملك يكون ريط هذه الفورم ضمن تتابع بدء م۲٣4]ءالتطبيق.‏ 

اذهب إلى خاصيات المشروع(المعروض في الشكل في الأعلى)ء »ضع حقل " €۸ع۲اsC Splash‏ "إلى hءھامS.وهذا‏ له تأثیر جانبي على 
إعداد My. Application .SplashScreen‏ لفورم اكaاSp.والآن‏ شغل البرنامج.سترى أن النافذة المنتشرة تظهر حوالي 1/100من 
الثواني»وبيسرعة يتم استبدالها بواسطة الفورم الرئيسي. 

کما رأیت تعديل حقل" ١۵ع٠١ءء‏ هام5 " يؤدي إلى ظهور النافذة المنتشرة ١۲۴۵ء5‏ هام بإيجاز.ولكن سيحفظها التطبيق ظاهرة حتى 
يكتمل عقد التحضير الكافي للفورم الرئيسي.بما أننا لم تعمل أي تحضير.فإن التطبيق يعرض الفورم الرئيسي حالاً. 
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أخيرآً سنضيف حزمة كود بدء خاص بقاعدة llبlilıٽ bunch of database-related startup code‏ والذزي سيأخذ وقت أكثر.ولكن 
حالياًسنعمل على تزيفهع )ه۴ .في وحدة اعلكه" إطار العمل للتطبيق. أي كود تريد معالجته عندما يبدأ البرنامج الظهور للمرة الأولى يتم 
في حدû‏ llبڏe)صStartup(‏ 
وهذا الحدث هو واحد من التجميعات الصغيرة لأحداث مضمنة مع التسلسل الهرمي۷« .يظهر الكود المصدري لهذه الأحداث في ملف 
Events. vb file‏ icationا4pp.‏ الملف الذي تضيفه الفيجوال بيسك بشكل آلي لمشروعك عند الحاجة.استخدم زر "عرض أحداث التطبيق 
View AppPاication Events‏ " في صفحات خصائص المشروع ٣۴5‏ 6۲٥۲م‏ اcع‌زه۲م‏ ومن تبویب تطبیق ٩٥c21ام‌م۸لفتح‏ ملف الکود 
المصدري. 

Namespace My 

Partial Friend Class MyApplication 


ENA CESS 


End Namespace 
لنفرض أن المتطلبات الأولية لمشروع المكتبة تأخذ حوالي ثلاث تواني.تتضمن الدوت نت الطريقةم6ا5 والتي تؤجل الكود لعدد معين‎ 
Namespace My 
Partial Friend Class MyApplication 


Private Sub MyApplication Startup (ByVal sender As Object, ByVal e As 
Microsoft.VisualBasic.ApplicationServices.StartupEventArgs) Handles Me.Startup 
ا‎ = Take a three-second nap. 
) 
ERE SUD 
El CESS 


End Namespace 
شغل البرنامج الآن»وسترى أن النافذة المنتشرة تبقى حوالي ثلاث ثواني(3000ملي تانية).بالتالي توجد فرصة جيدة لأن يأخذ كل من‎ 
قاعدة البيانات وکود بدء التطبيق وقت أقل من تلات ٿوانيء أعني» :نحن نتکلم عن خادم سکول ا1 هناء :من المفترض أن يتوهج بسرعة‎ 
„blazing fast 
لذلك من الواضح أننا مانزال بحاجة لتأجيل انتقال النافذة المنتشرة.إن الكائن ١10اةءاممM۷.۸ يحدث لأن يتضمن الخاصية الأقضلٍ التي‎ 
العدد الأقل من الملي ثانية الذي يجب أن يتم‎ alJ|MinimumSplashScreenDisplay1im¬e ةıيصاlخنl نحتاجها لنؤكد على التأجيل. .نشير‎ 
عرض الشاشة المنتشرة.القسم السيئ هو أن عليك إسنادها في مكان غريب حقاًءعلى الأقل عند المقارنة إلى كيفية برمجة‎ 
الفيجوال بيسك التي تعلمناها حتى الآن.‎ 
احذف كل الكود الذي عملنا على إضافته حتى الآن» أي احذف الطريقة من†۲ة†؟S_١0ا†مicاممM/A بالكامل.ومن ثم ضع الكود التالي مكانه.‎ 


Namespace My 


End Class 
End Namespace 
يحتوي مقطع الكود على الكثير من الأشياء التي لم نتكلم عنها حتى الآنءولن أتكلم عنها حتى عدة فصول لاحقة.يكفي القول أن‎ 
الطريقة ع7اةاآ 1هي واحدة من أول الأشياء التي تحدث في عمر البرنامج» وأن هذا هو المكان الذي يتم فيه إسناد‎ 
.MinimumSplashScreenDisplay Time 
۷6510١ الشيء الأخير الذي عليك عمله للشاشة المنتشرة ١۲۴۵ء5 51ةامء هو تضمين بعض الكود الذي يعرض رقم النسخة‎ 
ا٥44 عملنا هذا سابقاً من أجل نموذح في الفصل السابق»لذلك سنعمل هنا على إضافة كود مشابه لمعالج حدث تحميل‎ دقل.مumbeا‎ 
.وسنحدث رسالة حقوق الطباعة†copyrigh ا »افتح الكود المصدري لفورم كةام5وأضف الكود التالي:‎ Sماهك۸مروف‎ event 
EuUDIIG CLASS SPAS 
Private Sub Splash Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles 
MyBase.Load 


ا 
nel CESS‏ 


الآن شغل البرنامج ولاحظ كيف تنتظر فترة محددة ومن تم تظهر الفورم الرئيسية. 
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الفصل السابع:نماذج ويندوز Mhm76‏ 


على الرغم من أننا صممنا الفورم الرئيسي في فصل سابق, فهو متناثر نسبياًء وتتضمن فقط زر واحد هو"حول الا0ط۸ ".مشروع هذا 
الفصل يضيف كل عناصر واجهة المستخدم للفورم. في الحقيقة.لقد عملت على إضافة الأدوات لسطح تلك الفورم من أجلك(شاهد 
الشكل التالي).ولكن تستطيع إضافة بعض معالجات الحدث التي تجعل الفورم تعرض بعض حيويتهاİ22327‏ . 


ت 


لوا دون الع قر الأسفل:ومى تم أنقر زر بحت لزيد 


E £‏ 8 ل 


كل كود الحدث العام من أجل الفو 
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ا 


a9 


A 


2 
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الفصل السابع:نماذج ويندوز 
Mhm76‏ 
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القصل السابع:نماذج ويندوز Mhm76‏ 


Handl 
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الفصل السابع:نماذج ويندوز Mhm76‏ 


معظم هذا الكود يوجد لينقل أشياء تخص العرض.على سبيل المثال»يمكن للمستخدم أن يصل للميزات المختلفة للفورم بالنقر على 
الأيقونات أو لصاقات النصوص ذات الصلة على طول الجهة اليسارية من الفورم. كل أيقونة ولصاقة تطلق واحد من سبع روتينات(إجراءات) 
والتي توجد لترتيب الأساس.الأيقونة اليسارية الأكبر"ع†آ۲۵۲۷طأاء۴ » »تستدعي الروتين المشترك 115١2۲۷1١‏ )ئة عندما يتم النقر 


عليها. 

الإجراء ۳ع1,راaاطibا)as‏ ا يضبط اللوحات المتنوعة والحقول على العرض بحيث يرى المستخدم هذه الحقول المطلوبة للبحث في بنود 
المكتبة. 

الإجر اء eاs1nvisibاane‏ يعمل أيضاً بعض التعديلات على الشاشة. 

أحب تضمين النص الموجود في حقل صندوق نص ×16×80مختار عندما يصبح أداة فعالة. كل أداة نص ا×عاتتضمن الطريقة ا۸اام؟S‏ 
والتي تحقق هذا العمل. سوف نستدعي تلك الطريقة من خلال كل حدث دخول ١عا١علأداة‏ صندوق نص×80×٠۲‏ .الحدث الذي يحدث 
عندما تستقبل أداة تركيز إدخال لوحة المفاتيح ۸۷503۲١‏ .راجع الكود السابق (. 
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إن استخدام الماوس من أجل الوصول إلى الميزات المختلفة للفورم شيء جيد.ولكن للتعامل مع كيبورد(لوحة مفاتيح)المستخدم يجب 
ان نضیف الکود الذي یدعم میزات الوصول باستخدام المفاتیح من ۴2إلی ۴9.(راجع الكود السابق ( S۷‏ عPrivat‏ 
.((MainForm_KeyDown‏ 

فكل ضرب مفتاح ع )ه۲اءرع)يأتي إلى معالج حدث" ۷20۷ع ءوإن عبارة ٥358‏ ا٤6|ع5‏ تختبره.وعندما يطابق حالة مدخلة »فإن الكود 
ضمن مقطع الحالة عه يتم تنفيذه.ضغط المفتاح ۴2يحرر الكود في مقطع الحالةK€۷5.۴2‏ .والمفاتيح هي واحدة من العديد من 
العدادات الجاهزة والتي تستطيع استخدامها في تطبيقات الدوت نت. 

لاحظ الكود الخاص بالنسبة للمفتاح ۴4. فهو يسمح للضم ۴4-|۸من الخروج من التطبيق»والذي هو ضم مفتاحي قياسي بالنسبة لبرامج 
الويندوز الموجودة. 

عادة»جميع ضربات المفاتيح كع )هكر )تذهب إلى الأداة الفعالةوليس للفورم.لتمكين معالج الحدث Mai” ۴0۲۳.۸٥۷90۷7‏ يجب أن 
يتم وضع خاصية الفورم Wء۴۷ع۷۴۲عK|إلى‏ صح ۲۲٠۷۴‏ .ضع هذه الخاصية وذلك بالرحوع إلى مصمم الفورم وصندوق الخصائص. 


مشرو ع المكتبة يتم تصميمه للاستخدام فقط ضمن مكتبة صغيرة»فهو سيعمل فقط على شبكات عمل s١0ااهاو)امسقليلة‏ في نفس الوقت»ويمكن أن يصل 
حتى 10 على الأكثر.وليس هناك حاجة لتشغيل أكثر من نسخة واحدة على شبكة مفردةءبما أن كل نسخة تتضمن جميع ميزات التطبيق الممكنة.واحدة من 
الميزات الجامدة المضمنة مع الفيجوال بيسك هي إمكانية إنشاء"تطبيق ذو حالة مفردةapplication single-instance‏ "»والتي تجبر على إدارة تشغيل 
واحد في نفس الوقت على كل محطة (شبكة عمل). على الرغم من أنه كان بإمكانك إنشاء مثل هذه التطبيقات من قبل»ولكن الآن متاحة من خلال نقرة ماوس 
وحيدة. 
لجعل مشروع المكتبة تطبيق وحيد الحالةہ oااجc‌iاممa‏ instance-eاsing‏ »اعرض صفحات خاصیات الaشرg the مroزect propertiesg‏ »ومنە لوحة 
التطبيق ١‏ ٠اأهءاممA‏ »ومن تم اختر الحقل" اجعل التطبيق حالة فر Make single instance application‏ ".عندما يحاول المستخدم تشغيل نسخة ثانية 
»فان الدوت نت سترفض تنفيذ المطلوب. بدلا عن ذلك»ستطلق حدث llتþطبıق StartupNextI nsta ce‏ .وأية معالجة خاصة تر غب في إتمامها على التشغيل 
الثاني للحالة سيتم عملها في هذا المعالج.مثل معالج حدث الانطلاقم ںام5 ءيظهر معالج الحدث مء هاءہ!ااNexمstartupفي‏ الملف 
.ApplicationEvents. vb‏ 
من أجل مشروع المكتبةءالشيء الوحيد ١‏ لحقيقي الذي نريد عمله حقا عندما يحاول المستخدم تشغيل حالة ثانية هو التأكيد على أن التطبيق معروض من قبل 
وهو مركزي.بحيث يستطيع المستخدم عرضه بسهو لة . افتح الملفطv vets.‏ io”Eاca//مم‏ وأضف معالج |ئنحدث .StartupNextInstance‏ 

Erivate SUS MYASPIIEAEION SEA EUPNExXEI RES EanNEe (BYVAL Sender AS OGNect, BVVal e AS 


Microsoft.VisualBasic.ApplicationServices.StartupNextInstanceEventArgs) Handles 
Me.StartupNext Instance 


4 ج‎ HOEEES ERE Main EOEM EO Ehe ETON - 


My.Application.MainForm. Activate () 
End SUS 
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Mhm76 الفصل الثامن:الفئات والوراثة.‎ 
Classes and Inheritance Gr j Aã 
/EFê ãdn,ر‎ zOfê (OOP), KK qj {By Kã Aj D4 Ut (objectoriented programming (OOP)) REDGSET Dã 38ÛB 5 


Kod êêyA Avasic i ã êj M4 tt BARUSystem. objectBBÃddaDEONK oj OR ze 3) Fa 3ê 


Gã y&Ã¢@ ã3 (Ê KZ Î çekè û RbökêrDzã 33Û xü exkZÊG.Ö&elٍ.ÃsÛ. Ğihãdû Ağã& Z ao? BE ar 
Kqd ŞÊë&ê Z ÛFGã 


J zokgëëZ ŠÖ A EÛ #kéYn ÖÖHGÃyÖÖ Z çrÛ A: GEAÖBGAÛÎ BGOKÛ öxğ Ak EÛ Köãğj BG > AWö kB ö ZCPU Z Atã Û 
bits j4 ëEÙ ڑz‎ ?AwrzĞFEf ğ bo j RKEPAK Z7zda EÛAKöj 3S È AĞÃKkğ Kk ĞÛÊ tak fz KyğÛ Xêlê ãêêrDZ 
. bytes AKER 

GENEL DÎN.dOx Cê MS-DOS ûã ã&Ö BD Zz ğ RHOCsEDE ¢ûa/ËbpzO/dêcPU Öz Krnûûèê AKL NES Ue KëKOğ Û 
.Ö K& donA AN DÃRãğ KÖRÛ yZ ÖRkşÖ &Ö bk  Ö KÖqlaê OĞdb GHGLDTECGER CG 3) Ub Lz BOA) HOFŠTDZã 
EXE BZ YZ nÃsŞÛ KHÖĞkêr DZêĞ 3BMHÊ Ö (GaRNJgA A nÛ FëZA qêrORR Fez r EG ا‎ (b DiRêz 

3 DfEëĞBoŞbrdinary procedural languagesĞKEë A@ 9 ö 

. OOPLDZBCĞHHOECEBYaAKÛ kz yaÃ ¢ aê ÛĞZKÃaêr GED L Qy Oz j Atê? % SKkY ãğ KÛ BêdoRdssembly language 


| ê ãk dx BÛ Öngikö Ãî zt dabëk. objec ÖĞzL 3Û ëkebject-oriented programming CDBG Gf 38ADZ 
û KEOMBÛÛzêB Aëj AA (XAKÎ KY çê OĞEÛ A AKKÖğ A6KUL ğ RgÖĞË. noun ë rãcê Bã Û Foun 
.b ÛÛ Aş anã AŠKI #%ë ÖO) BÛ (Ê ÛR j aşî löÖÃ ã 
DAÊ Oê 2. real-world objects@4 UÛËzãB Këš ğ #5 dmê ãöĞö3Ö tê AKëgÇÊS dÃ öĞê wj 30Rê şğ MHORÃK 
dA ê {R Zê KABE ERs KrAĞozÛ Û7¢ êr dkEEK ¥ tags OFLDVDBZFAXEODY HHOBdo zk f Ö/Xë) ê 
Z tz zrBAAXKÊ ر‎ 6 AiR Y #HOkÎ Kotê % G û dh Qy ÖAbödOzDn/ op ¥ BAFAXÊÖBÎ n ÖĞKÖKK % ş ãÊOLŞ 
zKÃĞ! Ê edogiK e Sends ¢ êdl} WARÛEÎ QikÈ (GÊ & 
dnb yzêkULşğ Af 3ÃxÛ kê ŞÖYA do UêyÛzãB KëZ Š XT o Fr(gêA JG? B Š ZÊÖ/KÊ z#DZOÎ a KORO: Ek 
3 û polymorphism o j IU inheritance encapsulation #eMabstraction RD GEdHOYoĞrÊ Sj AS arb 
dnd Ã öXQOztf 3m Kn 4 Î A yaÃ@ akî doGÃÊ | BÛ" object dê" GO Ö têkî DÖ Ãã 
. implementatior AKRE f MÛSÖBZÖ tãrOĞR lL KÉ Ö GB ÛClass AğëKÎ ke tk û kçşizAkkÛ Û È qd AE 


/EA )êÛrêzãB Kğdo.ck/öt Gê ÃÈ j öj KR aêDêdetaÃrT êk Ğ&AÛ ö UÛrÊzãB KëëödeŠ dı.ddöof û B 2% AKDEEOAA 
„(5 BOOT ã 


Original Abstract 


uÛËzêB KğdoKT ZÖFšêöĞ $ 2% Ù êz & Ang AK AKG ZOD Eel DEêÛrÛz ãB KğdAŠ KT cp Aisêîn) Û KHÖYodOz 
ÖQê G&ÖROz û 4@ğéRDrAB F ÛOãÛ Û Ak AD EÛ (kY BéTEÎ &KÊ iA 3@EKÛ (ÛNA ر‎ zökY & 

Ö5 Y5 ÖÖIRk 7zê zt ÖhnéZ B&Kãa HÛãG ûş XG CÊrÊz RK ARê zl ÎÛ QitçãANûg ÛXDahnBÃ) Kz şÖXÊ 2ã 

< ş GÉ eaCDHROONKRALOE Y BY heta3P 3244 BAZEREKE KDESGtRBORK 3) KEG 

software objectj ff 3ëdeê ê &q KE f Ö KZY BÛRR &J he¥ËtöÛ êz ÖÖkqlkzş Ö; FkqlbDÊ KkgÃÖëğ ë&Ë ã4 ÖÖ 


„Mhm7ê اھچ اد يڪ ر ي‎ 
:5 ëÖDÊ kı MOE têde 

Aş KBr 1 

(b Eta KEKKA Ã 3 A)ĞÊ KBB êîN2 

EÊ RÈ 

«(j DAĞ ake dNGVBE a3 

êg A gYn5 

GA. ARD Edo, öÎDZOkd FO ŞÊKÛ QÖĞA ) Û ر‎ hêz È KEE 20l4 ak ã ŞÊ < Özöر‎ OE KEE) tok dê? 
dadëdh? cîq calculations jJ #Ë û {rocessing rules & Kn/ëğeBÛ Ûpropertiesj Rb Ã ö» 3kd#Öëz KA Ê KZY ãl ê 
. methodsèÃ) öêë Kr anaibA REE) properties 9 Ã ãEzş Û; HEĞÈ 

. members of the objectdiOğRR 3 zÖONEöKğASD Ã ãaW FR gn 


ĞËÊ şÃ Qê 3A 3. FÊ RÛ Ê a#ê taê; HëdıK Dîz Û'y ÜyAÃÃ(Ê E dÖz cd jA 3ëdoG FI HEGRE 


KKÃAÃ jarê O&O: FkzZ f 5 Af şê BU "ûû 14 PÃz.: Hay iGAroayÃê têb qAÛrA gë ZŞAÃ (Ê taODIDo AOR 


encapsulated Z Yé eG O) URRZAGF ER IG ULşy 46j êdmıkKÊ Z KF Ê kK5AÃ) ng Utş"AHDKGaY ãj d¥Y@ OFtk 


.ĞÃêğ Ã 7 têda ê AtêEÛ XR GR 3Û ARE 

GÛR öۂX‎ dÖrB az AAR AÃçãEÛ KêdoKëXë? BS) ÜMÖz ÃeçrkE O&) ork dkin ¥." /nterfaces J KDE QOoAeêkin.z HEG 
GF DRA khk.daDoGEh 3E Ab OBInOBAKY BOR BAF DB K3AKECE Ê U zOê kî O&ı id ARKEŞEÛ Kên AÇ6 
dabëyÃke Ğrûşûzè Fn KYÖdıdlOÖY (Ê t öş/Adeê db GQ êFAIŞKES Dk ğ ARK GOT FOR jk şiYA/ZÊ 
& Rad AKBZADKöYA aor FeckYy BDEKKEGO edAA hae He 

ÖB znîmouseã habisplayd Ã ãgükeyboard GHAtãĞjzûã?Ã\; ö# j ãk ëeln) Ğ&zADãj KX Dëëdb  ÖÖÃš ö kerE ORyaÃĞ ã ã 

„. power button Bêşlmicrophone jack) zzŞOKãĞ® ş speakers FOKÊ Gkports@A21394UUSB power connector ã 
FEğ kL OT ÖÖ êkê ğKDE3mj AKER iblackboxestkê EK A Att ğ DBA 3MA qy BOF j EÛ 
ã fn Ğa&dbÈ 3zêÃ KãUSB Y ã ãK#ëËÖOĞ öYA dnğköè Ay Ûrinter driver E BOÖEÎ t dz Z .5 GÊ KkêR nêl 


H3 DÃkĞEÈ ãر‎ ÛêÃ Êz Öç HëšL L QZ f BA şë ğÛ +! AÖRŞÛnexplicableKÊ AGÖÖë Ktzrz ns 


Inheritance Gt 
GEZ 6 #OFZÛ A ÖÖÎ ak AW K ê K aer EGR EED GSKB aZ A dORbKEGE ãZ Cake ke Ko ÊZ GĞ 
Kg ĞGZAQEFDğ SR 3R (ULŞ base classe? 3k03 Z original class GA j êEMÛhsŠ dod 
doj kêç ké tê RiğYEêD Ö5 Gx KBĞHayaÃ GQ Ãnerived Ğö) têz Kk UM 3EAXEÛB Aik ÜĞÃA oÃêf 
d0 ر‎ hz WAKER qû) êê #hnyÃ zÃ 3 5 ÜŠÖÎ ® NXE ŠBĞASê ny zÃ 3 BÎJ QO EBE 
REMĞÖ0 tê MaÈkê 7 A Rutt Ok AXKO®S KKkAz/NAdR 3j ãza. ÖOöüR Fea ãoverride ge $s Q\ i نة‎ taa 
ÖDto(j DR3 Ã Ê <? db ÇÈ animals ğ kês AkY BERKE EAONE KEEandEDBÈz Da A o AK 
GHEj dÊ Os zê Û têĞHaML RE32 U kr Ub 4ê AşîDzê 5 yz /Ö ãl ê A) tê jã 
ĞÛ) têz kË A AsO &gF yestation Ğ xêgs Xk Unammal ğANEECHodDz. Rê êd ÊD z Ö Û Ûz dîRXEÛĞĞ 
Z #Ö ãl è ãhamel è+êãj® A 5S AO? ÖGÈ avian &fÛ ã nammal ğ HxÊËğdoÖöşÃ K@BMNes Kk MÖr aviar-derived class 
j HixÊËRêšdoĞë JĞKÊ qîhnima/ ã3 J O8 avian &@¥Û ãdo,(ĞÃÊ QS SKE Ranimal J aê doleg count ÖDFöëş Species 
animal ) &¥ğ dogeneric instance ü Gi ZIG #X6) zokdögzrÛ do J HAONAÊZ rgd anima) 3¥ ) O8 mammal 
AÛ ö GAnÖ j KÊ Û & a0 A®a Qy Oz 

J zok j K3 Lb Qdiş GE RXBCAGkprivate GA) Oky RFAKOS kq #3 LC tê XE OEGHEĞdn Ö5 ر‎ EG) 
GET oR 3Ê 4 hz OX KBOHEgKDES Ã öR 3j KÛ ã3 É G û sFkr ëÖټ‎ tê ĞÛÛ taĞë6ĞÊ êê 
GHêZPublic yö së ÃnzR 3 E 4ë) têëĞÊ Kite zon nds AŠ%hQadork dE BY protected 
EXë ?غÊ‎ n APÊ nÖÊ bapFÃĞe XR. öXÃĞEG (Ê ı32 ĞÊ KëKËZNR ĞÖ) têdi ONEN 

GREER 3j ãlDt ÖãÖ E 3š È Hod Uassembly3k ÖãÈ Aq TORBOOOĞGAN) Okîîriend EXÖ ö G5 FHêR 3j &iriend 

A stê Öêè cë &ö BÛDêè qêêrnãÃ¢ ãl Qy ÖzPublic 
nê ĞFDãKXEBĞAÃÊ ö KkeKöcKXKXBĞA EO KkeAB/ daê UL &Ê kUêÛrÊËzêB KëZ Ë3 DEGREE 

kk ORD KNEE) nBağoyDeogyDğA® Ã ã0 ĞÊ Kêk î A Grikz ff BÊ ¥6 
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CS KYĞBÖZ GrÛJ GR O3 OF kk Öqfiinnb on ¥$ GDC: 18 RoyFÃ@ ê Akl QY e) ¢êG û KzAÊËKZY BÙĞG 
ĞË Z " typetzép Ê neflag field gf ÛÖÖj j ê êz: ffaggÃ qğozûj y&ã¢ ê 6K 30 ê F  ĞBöÖĞš non-OOP languagecDZğëi 
.g[ mammal-specific fields GBzad AX5orûj yak ¢ ãk ÖOBFÛ (Ê Û mammalğ #X5 # Z6K Ošy- DECKS K4ĞBÖ 

BIBFD ) Okan Rêda çêAÊ ?AÛDR oa 
gKNJGÃÊ qBzO,ر‎ Oz GO) AG j . " many formszédrgE'"od j öêkt MAKA af Ut Polymorphism ol j tk 
ok, ON MOE Eheneric animaNB ) ã ÖOšunammal j KXËKëdeŠ K Hê aX Ğ#özÊ 3 dmê ® A (overriddencçrOĞ 

Öö ëÃ ÖO¢ êBr ãk FAO j ãËk KÊRÊ yj aê ö&ê nêÃ¢ ãL qê öR 3j êd aê BG aî KX GR Fee 
KEöşderived instance Ğ) nî ĞhÃênÖf Rt &Ö Bj dF têdno/dî j êËkO# Ûeټ‎ nÖf AëpzO/ê šã Ã j 2 B9 
doj HSŠ co dîniiêanimalj Tê) KŠ 3mÖOKiQK géÖ/XŠ) È ê. FH 3 U KFORĞKD OFEkyãç base instanceĞXğ/ê 
subtyping 3È od Uke Kvold' j ãštkdot zAë& .Ö; re ÖGê {êvian aû manmaky Rx5ŞÜanima) ã4 tz 
dONkZTruL è r Ak FIdmedXgholymorphism 
1 ON (ı sê tãğ KÃğëÈ digin Ğk GON Overloading Z AKKëGsÛGĞE Ê /N' Overloading Z KKêëGê ÜzLşod' j ÊOAÛ Kk 
RA öYQÃ3Û ÇÊ Rbhiãj zÖKEê ¥ ëê)' ùrÛ " ĞÛRÛ 3m ohn.dağë Ö XÊ) Ë aî Ëıg hin ĞO ö A KBã”¬ ÖGÈ Brg KNKê 
GA gfe gê Û QAZE .(ĞZËÎEKÎ Kı zö/ÊğbÊ Fé) ûk qöoĞk?Ã Ûbrù ĞONR VS &) Ye onjãürù Jjşر‎ zÖĞkY & gi & rù 
ÃĞOY ãĞKÊ êj YnKtöĞûN 5B r ãz KER KY ãJ ARK? % &#K@ + KE /ÊÈè ãlL qè &ê İÛBÛ DRö¥6 Gin Z Xã 
«AšëşŞ 

GHAEOYPS EZ (O ÃAğ HEyaÃĞ r YX GHBOKFAXDa TDraROBGHOyAEEZ KEK azDZ GAS G E Kk(Aë)èAùN\ 

GÛ &? ArT \BEvÛĞÛzêyÃÛ Ru BKEN ãyKÛ ãĞ zek dê HÛ n.ıZaAikZ 6 vê 5 kak AŞ bö 

doré Aplmyê Ö ÖÖÎ aêÛrËzrêdsO&ö Xê ãZ O NZzWVAKBCTD®) interface DAME b kt yKÛ ãĞ: d2 8 BEZ D 

OLS FRR Û AOS 

j Ak) hoz. ĞDEëKÊ O ĞÃŞ UL ŞÛ mplementatiorRAXKëUL ykÛ B3 ONG tÃãZ K EEE aÊVÃÊ têo ã 

KÊ Ok Û rı UÃAzğKëöo Kids UAU J zONmplementation FAKES RHÖĞZ .Ğ: aş EsÈ AqODEnĞAY' L 3Ã r Ö@ do ĞAN’ 
.( FÛOtêN® nz )ö #k ÖĞÖüğÈ iar FÎ tûdg UAU' | ROREL E 
ر‎ Ûhz K Fk ödeš Bdn AÊğEĞ: #ÖBÖkeÃAÖ KÃ ûrê /nstance ĞÃÊ Zã GkabbjectdaOrt NG têde YEXÊ KBëyKÛ ã 
KÛ ãBdodistinct instance gk QĞKÊ qOXÊ FÈ lL ZAÖĞöŞ döğzsÈ AqîGÛ^ 


di z5 ze AşUÛÊËzãB Kãğ #6 3n) YK £ 3Ã @Ê OAo.OÖ ر‎ UN KYO AOKBOKEK Ê PHeDEBGHSOBG 3 GEEEEY 
ÖÊ baDFÃğL DÃDöYA do,Ãçğ OKA. daORÙĞB.Û î7 è trad MOTE 3giÖz bT ê Z Nê Ãjy Û n ĞZFÊ ã 
.Örê i 3Û bre D UUBZê ÛJ ãêj ŞÊ Ö3 dz ÖLK qi E: 3 4Û 

Ö5 Öö ر‎ Ê ãh.deê dnöDÖQ® A Ko ê nz dî ÖÖ ر‎ ÖN ÙËz cd Kqğ ÊZ BBZEWè ù KORO û Kê 
j RHO ĞMKÖ ÇBGÖz; ã3n Bš ên % KÊ Nj HHÖÖÊ baãDÊãGÃXKk, i ۍ‎ FB È Koj î ŠÖر‎ Ug 


Ğ YORUFKOO AB&L Z Kk E K6 FEozG k OÈ şj HHOĞEZ Ktstructures EBiclasses ğ RÃBÖÊ èoaqDHğyAÃ(Ê k 
Bê ö GEZ KGxcClass gtD#ã 


ÖÖÎ #iş ãûû AğĞZ TeX ak. ökê ÛR zZ 3KjRiEXP . ARL è iClassgkD#ãĞ: 0ã GAL T rz 4 
7z tê j êR z3 îtî tê; A MAS Z ãã KEK3Û (Ê Kûz ndnËtêeqk Ê kZköê ÛR zZ OAT êr #2ê 
e ÛR zdméOFQêê j ãjùR AÖKÎ Q Namespace ® ;j öR Zz JFK assemblyÖFt Ötop- -level namespace 2 %j ã 
„(7 j ãrzÊ tã 
Namespace GoodGuys 
Class Superhero 
HME CII 
End Namespace 


VK ö KAXKKL qè a FOB Z hékWVindowsApplication1 zL U Er ةöêXÖköê‎ ÛR zر‎ Ê ãf 
WindowsApplication1.GoodGuys.Superhero 
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dO KYLE oe aR ZZ Arr kaş è +ã Ãc§Ak(Ê kY Bj KABE j öR Aöğ RKiëdn#ë BÛğzA BÛ (Ê Kk 

Ğ ÖÖ z2 K3 kêz BÖ n&zOöğ Ang db Ğš z Xk Ê ÖKğZABIÛ (Ê k End ClassçClass K GEEK aby öR 3r k 
:Z MKKBZPartial gxD# ãĞ: YOFRDZêdo. Aj & Ög ã¬ db R Qy ÙEz Ëk Öã 


EaABE al GlaSS SUPGENEES 
ERG CASS 


EXö Protected 1T ÛPrivateî A)Publicyğ:ozd zãğ @Ë gîD# ã A Oğšdo ê yaÃ ¢ Aêğ Kaz Xk qû Keqêz #Ëk3nÃ ö 
. Protected FriendlkT EXŠ Friend 
K Dêrê KAXKKL KÛ HOR j KÃB3rnĞ) Ê GENET Framework Class Libraries (FCLs)K qj yÊğšĞ: 3 iı ÛĞË J Dr OF Ok QA 
"" Classé"ûÛ Ê çîD# öĞğ Oê Ê Gdn 


Class dıÉ ãk èãrT kı Ez jJ RAER 3P .Nonembers Rf 3 BZ ff KB 3® A geBÜÛXHZf dëîSuperhero ÖQÉ és ã 
OR BEA CAKtêDZĞK ëëR 3j ãprinkle ÃSğÛ (Ê RGY Öû ÃAPartial gê VÃG ãۍãğd‎ &elok dF B End Class 


Kb ECE SETL jû 


cdalhvVoikê KNööR 3ç top-level membersBZFEërz(Ê têd ûk E Öz BÛRA Bk aA Û QY BOE GFDARG HOR) ad KEQã 
Jaf dmêayaÃ¢ê ê KEQöZ KKL QEKHEÖYkyAÃ (Ê E BÛÖ@ do Ö: ¢ ödogšèğÈ Ãcz s Kn&Ö ell qê Öz zBdDE 
access modifiers Öz 7ã 
Class Superhero 
Public Name As String 
Protected Trueldentity As String 
ERE Class 


ok /KKERK GérsG 4Û FADBÛ ŞAKkÃ ö A oz zãdÖz Ğ#ÊëJ KEBQĞ KÃğëB Û GA Û qOĞE Ang ĞFêÈ KBQêozÖj J Û 
zÃAÛ kv. LINQTZOAKEED A RHêR FeŠBER QÊ êaDÃa 3P 3n Bre Hr zê) Mok dn ¥. ÖOÖHÖĞÃ Ê ã 
jz gë Zproperties 4® Ã öyéğÈ .KBQãozÖj öR 3ÜMoDienembers SR 3j ã®ض‎ A yaÃ¢@ ã3Û (Ê HA ÖyÛöÃ n 


local GH ûj DEPÊ n? Kêt SBA ö. ConstgtD#ãĞ: YOĞdi Ê QORÊ KEQêۀ<Û‎ O3RARBonstants K ë3 Ak 


KBQLKYj #Ë > ĞR qiterals GEKöyãÃQ Aê4Ö tãOۍZ‎ ŞK BK #Èëš6Ğ: f /#Ê Kk Ez ğrocedure-level constants 


Private Const BaseStrengthFactor As Integer = 1 


AAPA; ãğ¥ÊRiL RÖš,ö &ö Z KnãÃ@ ã0 @ rzÃKÃAÃ.Ûû ix Hê GE kL fej REK Kk 

Private Enum GeneralSuperPower 
Flight 
SE EMCEE 
Speed 
VisionRelated 
HearingRelated 
WaterRelated 
TemperatureRelated 
ToolsAndGadgets 
GreatCostume 

aE MO 


ûû OU Gx BRE ÛR Z PÊ n? 8 XAXKKkL Qy UREA FENA 


Gû tad é4&Z ÃÈrT NÖÛKÖKZ logic code ÛÛ KãKORÖS. functionséğfkgubs GEES HDA Bank 370 AAEdb R (K 
ÖûÎ dE ãEÛ XêR Fesub AE 3ü: Fk. Z KORã. Ûd QHEKÖÊ Aqêkk Ö&îğÃê A Z properties 0ã 
KÊ SY YNnAtöUL XA gË taj KE? ¥ GE FBNã 


Public Sub DemonstrateMainPower (ByVal strengthFactor As Integer) 
٢ Logic code appears here. 
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dn (KÎ AGËDÃÈ,&ê dJ È aR TORI ë ECVE ã3¥Û (Ê KDQAÖYÃ zê HöDemonstrateMainPowerĞÖÛ ã 
data ĞÊ qğ Ynênğ ëef Öš KkĞîÛR BGA j ãğ/#È ãzêrn dıٍBd@RBtrengthF actor êĞûn.Û fê ş ĞÛNÛ ãZA. dı f şÖGÉ 
arguments 


Exit Sub Kqğ ŞÖ@ ûÃÊ nk ê ¥ ãyZë ãgiFEE{ÜReturngFEyZÃ ¢ Ak ç BÛ GÖNÛ dn š $ ã37Û (Ê Kk 


yaÃ ¢ yêkKëĞ: Ö6) A$KEšt zO Odûreturn valuegêğ Ğ fek 3k ZOsub GEë} ã#DZêèA R&R cê Kunction oêèA 
TORO? GK Br GHEL è ã# abeturn giFKEyaÃ @ eK taĞ: ROB BÛ (Ê kK GêzZ KkGKE As f Ã ã 
Public Function GetSecretIdentity (ByVal secretPassword As String) As String 
If (secretPassword = "Krypton") Then 

aa 1I created a class field named 

' Trueldentity earlier. 

Return TruelIdentity 
Else 

GetSecretIdentity = "FORGET IT BAD GUY" 

MEL UE 
Eme EUMEE ION 


yAÃĞ@ ãleturn value assignment FDREĞ FÛRê# q assignment-to-function-name style GÊĞL èÈ r &% qê yK vÃGĞ. ةة‎ 
KeqgBÙ U3/KÊ taxOĞۍb‎ UBEFNOExit Function انل‎ 


read- Û Û DOŞ read-write GDR FO A6 A BÛ (Ê k methodsèaÃÛ fields oz EêgOzP roperties A46 Ã a0 
0 Ûz GHC A ë K6 KërOa." Set 3F "Ş"Get Ö6 jgã accessors JY ztãoYnA dnwrite-only Û Êz ĞGKDoŞ nly 
EUOlITE WETECONIY EEODEEEY SEeCEEFEELIENEIEVY () AS SEEING 
Set (ByVal value As String) 
TrueIdentity = value 
End Gel 
ERG EEOPEEEY 


dor Ö E k,Öö jşdağë Z(ĞKÊ Këğ YnAtê/#O RArAYêiçÜmethodèÃÛ ralues L OoxxHarguments GAÊ qğ Yn KAÇ Ak 
j KiĞèÃ0 ög KBKBãS ãıÈ êè r ãÛ 3DZÖ3DÊ ê êz Kink 3ÖöyÈ ÖÖÎ ar rê @ ãlL Qj Yn 


EOE VEIEGGES OUD CCNETI CE ORO SLI(E 1 SEEN aC BS IEEE) 


Gy BZ KEMER j 3R z?ZKÊ n2 LX ARKKL kv 5 Ûmê R AG ن‎ 


yÃ(Ê têyntax BOY Go db o/OY G& actionsoktkj ãğ 3Da j KEÇ BIM AQOOGE OW (Ê t GHDOQKéQ E UĞAÃ Û 


HERE O ëe ¥ o6RFÊ nêzktêRî KAÃëOÖOXFš/E6 XëyAÃ (Ê nıdO&ximethodêëîR) z X#KğDëۍŠ‎ cê nyo ã4: ãz KÖ 
.q/ëã{signature 
حص ا‎ Non-delegate definition. 
Public Event PerformPower (ByVal strengthFactor As Integer) 
Delegate definition. 
Public Event PerformPower As GenericPowerCall 


ê Koj ŞWAKDLL ğûãš/#è ã3rÖ redBngbxternal GDA DLL j ANZ š Kink $ /#è Declare GAÖ gS 3G OoGKK 
êÃÛ êz KKğyZÃ(Ê t6 Ağa 5 Ûzak AGO GE6Kk 


E CES URE LO OC a E ا‎ E MESSAGE 5 EE As E 


/Ë BéRyÃ QrÃ DLL UOFÎKEEÜÛ REĞTDrS Öf ik ask GOD AKEBOOS t2 E Fan K DK qd ŞêĞ: 3 i Üyçînin 
.evil. dll gk Ê n HÖFNÈKÊĞÙ #ëĞaDrK Ê aê AUDÃ ã"unmanagedëKBĞË FOBImM O KGEZES AÛ QY : 


2 8 ğADFëzZ Kk Qy Oz. class templatesĞ FFdÃyĞÖRÛ Babstract classes gk ğAšk Z #knterfaces 4 XDFEOOGHKK 
OD UL BEE j öR z Pz n 


38Û (Ê kên " chiladazëdÃ' Öh,ë KFDAğKEUTRAER Ã ãړr‎ nêk ¢ šêDîo? AÛ ãkçÜ Gù 4 ğ Aêêbcb R Qj Oz 
36Û' parent Š#ğ ĞË yAÃ(Ê rö ĞRDoğ KAB (+ )NÊ Hex Hê 
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Class Superhero 
CASS SUSE PONCE 
HME CLI 
nal CIS 


2 WEYÊ e j oR zÈ Agob? GÊ, ğ A öÃ dÛdon’ i go overboard BDZ HAKkr dOoARKEE 3 BaÖRZOy) REOFDD qne 
N Ö5 Ê8 چ‎ 7 zakho Öz  ÃÖz A ORF dan KOBO DZS SEG ã 
tö BREHKBüÊ zkBüêk oR 3ÜğA ÛÛ (Ê kFQêdıK Sz kĞÖSR 3j êd Û variety tzkĞÃ ل‎ 


2 GFKkĞË dmê Ğö /KÊ Bã Ş?Ãj ãj KöĞe Oa 3 krşHÊ A Öö 5 ÃO) KU ZOR GH DEK ( (GH ğr A); MOSES 
ÖÖëĞÊ Kê Qıı ÖN j AT têĞAOY &ĞË& jb A şèÃi G işê öR 35 cik Q;RKEÞĞ š dnb î A &ê ÛFKêĞÃAĞ qÛ 
ک.‎ 
variable KBQ,ÖĞz A ëÖ KL QY hOzShared GDF ê ORGAŞ/Š kl f Ö kZShared GDEêĞ ÛRÛÖÊ eaDFÃAĞdb Ê (k 
bQ MOE shared member 5A QöR 3j & Kêz oR 3j property Gê A ŞunctionGRCON subt A BéOR eld 


zf Hêl ë ê GEL ê EN ê yaÃ@ RESA QöR 3j 4 5B KÎ KkögtMEÖ¥kdounstance GS ت‎ qmDEã $A n&ÃQ ã a 
Class ClassWithSharedValue 
uOLLE SMaATEd THESE EdMalTe AS IMtecez 
CLASSE 
later, 1n Some SLChMeEE COde... 
Cae Ce CMENLuE, Tear edMallê = 10 


hRZAKHEêA ch ROA Q6 kê GHAEK q 3A0 @kjnstances ğrA Öö Z " shared 5A QÎ; ÛL 5A QöR 3j ã 
o4 BÛDê kı Ûr der 5A QêèÃ ã Û HN Şdaê GS EÛ (e ¥ Û û 0 t5 gf BZA zdsê GS BÛAD+ KEJ 
. Instance members ë4 oR 3ë KkK5A QL Hi HFkL QB ¥ Rk oR 3UBUMeORÈ AKĞë5A QıKBĞBJ KEQã 


ke kinc 3 OOOverloads gtD#ãğ YOBèaA nethod GOR Z Kk h/5 
Class House 
Public Overloads Sub PaintHouse () 
٣ ڪج‎ Use the same color(s) as before. 
ERS SES 
Public Overloads Sub PaintHouse (ByVal baseColor As Color) 
سے کے کے کے ا‎ Paint the house a solid color. 
mel SUS) 
EubIlNEe OEE I SASS SUS BANDEN OUSE REVUAL BaSeCOLOE AS COLSE, BYVAL EEINCOILSE AS COLO) 
0 EannE USIAG @ maln and a EFI COOH. 
E SUS 
Public Overloads Sub PaintHouse (ByVal baseColor As Color, ByVal coats As Integer) 
ج ل‎ BOS SIOIY Bane WIEN Mmamy COSES, OE DAME 
"EHA TS, MOE OE EFADETE, 
ERS SES 
ERS CELASS 


L ê &ö İBÛÖÊ HbğDFÃEZO/S Fe Htaj &Ö qd & E KY HÛKÊ êj YnÃtêöğo) ÙËz PaintHouseĞûÛ ãL3/KÊ kS 
iP KË zKë J nÃpãر‎ ûû A ĞKÊ KëğYnAtêdn3ê zq vakê KëğYnAtêsignature 3fezk? % ê ©+ êenğÃĞ ã 
: coats? AEF Ê KêÖnKtöğë Ã EÛ ® GEKA Z | é6 e dkndkÊ 3 ê 
EUDITE OverIl GaAs SUMO BaIRNENOUSE KEYVAL WMALEMCEOLOE AS COLOE) 
EUS Ee Omer OadS SHS ESIDNENOUSE EYIN Base CO OE AS COLO, Byyal coats As و‎ 


coats Û ê ZÖĞÊ Kk optional argument BRQëF Ê qîr kngghirĞOÛR Z AZ ã3FÛ (Ê Rk ê% QıK OR Zz KkdnDiEe 
EON E OuerlOaGS SUS ESOINEHOUSE KBMVSL BaSeCOlOE AS COO, OBEONSAL EVAN CEOS AS IEcgEes 
(اآ ک‎ 

ا 


J Ok UEDA ÊSÊ ê A ê ZaÃrT kı Oz dog A rê dn. BÛ HraÃ@ ل‎ 9 MOÖeOptional GD#êĞ: O 

J EÛ (kK qû Êğöoãkk.dOşdoats Ù Hê zÖĞ: fe r ر‎ Mz U3/KÊ têx OĞ&ر‎ Ûinul dên $ i ER RBĞKEN+ ãğkÊ KëğYnÃtê 
Zz Kkdi? ÜrÊ ê» qêyãÃ ê #wefault value ĞÈ Rê: fedi f QEBRQÊ Ê qîn ÖöãÖlLşF Ê qrkîrÛ rê ş Û ÖOĞÊ ^ 
= 1F Ã ãoYA doi GÊ Fer ãğ ÖByAÃ(CÊ Koats BAMr öF Ê KëONKtãÛ fê 3 
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base ĞXğ ĞEĞHEs È KirECFAXK( ancestor-descendantĞêrê J4 Û ( REDE Z kK zÛ HRKĞÛÊ êaDFÃAR} 23/k 
Inherits gD# öĞ OãyÃGĞ Aterived class ĞÛ) taz F ÜZdngdlass 


Class Animal 
ص ل‎ Animal class members go here. 
ERG CLASS 
Class Mammal 
Inherits Animal 
ي‎ All members of Animal are automatically 
I" BaEE Of Mammal, Add ad RETO alL Mammal 
' features here. 
End Class 
Ö@ KÛ zê A EXE EĞER ê ãÈ ÃAqob A y Ez şĞARBOR 3j Z KkelOcs Haz Xk AFT k Uz Inherits giFë 
ĞXğ/ş ĞË yAÃ(Ê kı êz éö) tãĞÃÃğ ÛşÛ Öz 3Û Öšdn.4ğ& ZInherits giya r šADÎPartialdtD# ê Oãyak ¢ ë0) tê 
J DOr ŞANO eê nj Ak gë 4 Ğxë KEĞHayaÃ ¢ êb QY Oz) .& 05 4 Û Êz gklnherits GByaÃG@ ZAD! Û Ûz gûn. 
(PA ÜĞÖê nj KÃËöĞÊ Kx İş Ğšiö KËtêrê BÛ tagayaÃ ¢ ãط‎ A 
ĞHA&Z s Kinz Ëöî A HA şÖ Ö o KzkëX né K Dj êr BORGER 3j ã3Pص‎ 5Ü aekĞû têy #iĞ 
Dã Oğselêkêe sÛ QJ j KAR HoĞXEÃŠEGHEGt Ê kı ÙËz (16K ÛN L Qëãşz FëÖĞeverrides ge AFkKEzĞXğÃĞĞ 
Overrides gtD# ãĞ OëyFÃG@ Kedi Uk O0 ta RÃkzk, Uz (2)ŞDverridable 


Class Animal 
Public Overridable Sub Speak () 
MSE OS EEE.) 
ERS SUB 
mel CIES 
Class Canine 
inherits Animal 
Public Overrides Sub Speak () 
MSGBOX (Bark. 1) 
ERS SUBS 
MnO CIA 
ÖDêNGHÖ Î &È AqbkxSpeak û0 ãÖDn.Ö Ö Ãt&î Ã ãÃ&ê Kk £30 (Ê animal ر‎ j ĞëdıEG ké BÛ Û 
Ğ OEyAK@ & FnÖDZBattribute ĞÃd ãtãdA Z xöK DAĞODDOSGKDEöĞ ORANOL QÛCanine 'ãYÖO&ĞÃË dmê têğj AŠÃĞ 
Gk KHL. GX Šëğ KAUR 3Û Û Ğöû taz Û Û HnêÃ@ طك‎ QES KO FD#ãĞ ORA ) zÖk NotOverridablekD# ã 
dni) tê ëdOE O verridable gtD# ãğ OBZ <Z Ö i k GX ĞRBĞĞÈ Aq UF #ÃQĞÖÖÎ onoverridable ROOFS, 
X5 EĞER ى 3ا2‎ 
Cla SS Cani me 
Inherits Animal 
Public NotOverridable Overrides Sub Speak () 
MSGEOX (SEEKS) 
ERS SUS 
HOG CLES 


dê î A &ê ÛF ر‎ ê ü n ĞÃiöz kö dozê kı UNE ĞEGHEZ A Gh OR GH dF têd ON BjçÛ 


Class Animal 
Public MustOverride Sub DefenseTactic () 
End Class 8 
End HXKëÈ KDefenseTactic ĞONOã) 5 gûr A AlyZÃCÊ kdökEÛRÊë î A &ö FêkdbÊ (j MustOverride û Ğ FER 3j ã 
. deficiencyÖÛ xr FÉ OVoĞpaZêĞk iz FRAT E46 nê FDIYÊ /KÊ aSub 
doٍğ+ j A HOE têdo,È FOL ŞO kdb? 3] Qê DefenseTacticH#ON K B/EB Animal) aê di KÃ qi 
. MustlnheritgtD#ãĞ YOFSBVASHEL ëÈ Şk QUXEUA. dnÛ YÃQÖ" MustOverride İS he Ez "SR 3U8KDY Bj Kã 
EOI TE MUSE IAheETE ClaASS Animal 
Public MuSstOverr 1de Sub Defenselactic() 
MMC CLASS 
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Gã. do,ğ+ Ã§ öÃ dq Kv ğ Fk è0 ã3Û (Ê kÖödîork dRë? YA BAnimal J Q#ĞĞÊÉ dni öÃ MOE têdodO/dê 
Animal-derived class E (ECE n JÊ ş( reference typebFDÃãtzKëdo} Animal) ã6 KBQyĞÊ dBFÛ (Ê HêZAğ Kã 
.ı @#êKBQ)zÖ 

Dim zooMember As Animal 


Dim monkey As New Simian ' Simian is derived from Animal 
ZOOMEMOEE monkey 


BÛ ÖÖ CF KIO aJ AAĞÊ Kişëkke ãš 8Û Qê Kzè KE 3ME ARORSGÊ Ki EB ERK KORA O 
WzZHÊ N6/ŠšÖö Ai Ã öةÃéê2‎ ¥ GX ĞBĞGHaA rÊ GN bBkdOGA KA /Br(ĞS)ĞKÊ q3 dOr cîh (® 4% Qã 
.Notlnheritable gîD# ãĞk OFA ok 


NotInheritable Class Animal 
Amel CIASS 


a? ÜÛ n GiöĞXğ/ Ğö Hnak@ OOF U Aki öÃ ktNotinheritable Cr Otek KL yat ¢ Ff TECO & 
E ھک‎ qDEã EN Öz zab QY O 4 QR 3b Bcnoninheritable Cr YOĞFk KBEÛÖ Gz 

GOOG KUCOverridable OOOsk Overrides OES NotI nheritable ĞêRYOÖsêë KUÛMustInhe rit Ae /Êz Ûnheritsq 4^ 
OAT Ğë: inimitable? LA e ¥ &giD#ãğÃ OR MUga/DZe ÖGÈ çر‎ sËbÖÊ êaDFAĞgIDK Ê féga.lotOverridable 


Öö ã4 .ÖXE ĞEĞEZ &vztL Redo. TOEzûãn) ÖONORUZ KK AK ãxOĞyÃÃ (Ê N Ez Në GÉ ZÊ 3 ge Atk Es Shadows 
GH BBORERGEY zool 3DABKORString GEÃãĞfÊ ¥ & zaolok KÊ q& Yin 3nfunction GEBCĞOR) g¥eoverride hU gU ûdi 
GAT tak 3j E kj gO Qê OA KöÈ OORT tak 3j aE EOGÊÈ aû ÛkÖ yÃÉÃĞ(CÊ N UD#lhnteger return code 


Ê ntÃËškëON ÖKêر‎ aî Fë zakrëkG û 3Û Ê K( grabst ÃŞpãã/Ö Qk ã5 bDÃ\ÜtÎ ÖöÛ Ûz Lè r RëXEKEĞHĞZ Ate 
nested ĞAAR,GE şlbnumerationğiêë şiËbonstantK aşqiKBQLOONĞO) taABZ eT K3 Ê NEABHGEZ PeanutButter 


PeanutButter BZA} Ê ngclass 
Class Food 
EU6 Ile SUG BeanUukt BU ECE (0) 
HRS SUS 
mel CIES S 
CIASS SMACK 
HnMeEIES HOO 


1" Hey, TES NOE even @ SUBE 
nel CLASS 


P KëkKsgÛnN çê ÛBnackĞêZshadows gD#ãĞ: YOã) Şëe 


creating class Gk ğ+ A SA fiëçgÛî ã deriving classesğ #Ãëè i) ë&FKBgUT ã designing classes Ak f Ö KBŞ ãgUÛî ã 
GO û ÃtãÛG@k dvinstances ğr Aj öŠA cqNew gitDtãğ YOROÊ baDFÃğyAÃ (Ê kinstances 


Dim myPet As Animal = New Animal 


OE‏ ڪڪ 
Dim mvyEeE AS New Animal‏ 
SE‏ ا 
Dim myPet As Animal‏ 
ا _ MMEEE > New ADImal‏ 
dot GÛ ÖpÃšyZÃG@ KR 3oê zãdOzşK qã ŞÊ6ĞTS KBQLBÛÖĞYAnêÃ Gê ãl Qy MO G&ã‏ " 
myPet.Name = "Fido"‏ 


O) ta XEĞËËL 6 KOkK aê j KEQ.ARIVkKEÊ ÖRZABEO Kk 


Dim myPet As Animal 
Dim myDog As Canine 
myDog = New Canine 


myDog.Name = "Fido" 
myPet = myDog ' Since Canine derives from Animal 
MSE OX (CMVEE E ame) E DS laySs EO 


narrowing EWÊ GBğYAO ® Agbargpêk 3FHGOOLE ? 4 E ökر‎ TOFÊ bKt On)é Option Strict EYEE K FF Şa 
oBdA & $ CType GHÊEyHÃ@R 3Ö AD! AãA. ÖšZ .(6 #& êãKEQêZ RÈšEZakdöĞ%Ö tãj AKEëtzaÖ¥6) conversions 
.OxHGëK Ok K qj ê ÖÊ bãDğEOG@ dmgxÃêã A tã 


myDog = CType (myPet, Canine) 


Mhm 76 
hÜxÊ AqêMEZA dn.ëis yA NBCEKORÖDÎH GED 34 çîk ã3 daî ieQrE ÜyÃ cãiÊ ni E rk E. قە‎ 
Ğ OëyFÃ@ ãglhualification e) yA ğKBOvL FÖş OS oR 35 kî KÖdx(ÖĞÉ èÃı dongé& OMÖGY db KORODUD 

Me ® Ã ûãkD#ã 


Class Animal 
BEUOIl TE Name As SEEING 


Eüublie SUG Disp layName () 
HIEReE Of ENese lines WILL WOEK. 
MsgBox (Name) 
MsgBox (Me .Name) 
ME SUNS 
End Class 
Z2 Gi GS dio lk VES Z XÃtaUÃAۍÉ‎ zãO Ö ÃGëR Fer XöÖdOxMe gD ãĞğ: OBOšrs 5 (kg MyClass Ã nD &% 
ğ#FDÈÃ animal) ãj ĞÖKBQ,Z QA dÖ&î CanineãYOğ Ğ dmê KÃ fêl nışÜĞXğê)Z YY Ğ tzqolnKBOy 


tړ‎ nZ yÃ@ ãdk Animal) ã#éj &Ö 2% ŠÃğè MyClass Öğ AÊDÃËyÃ A#šğ Canine ãYÖOğš&ê 2% ŠÃ® Me çîpê OByaÃ¢ e 
ĞHAã&Ö K aãk êy êdnn) zÖON ARéÜDZQOKÊZAĞnAÃ(Ê kak ğr A ĞJ Ê Bj RÃGĞ rak T FrODngûÜv AyClassĞDtê 


Ê n ĞË Ö/Xëر‎ ê ai ڑz‎ ã Kj ãĞĞÃ\oKÎ KULEK SEY ZKRN ROEDER KMyBase gıD#ãğ YOĞKÎ Kk 
E KÛR ZêZ ¥ GRClass1 dowEê KÊËZAY RÛClass2dÊ AEټ‎ KY RiClass3dmwE] KÃAُREY RDlass4 dE KY &LClass5 


yaÃ¢Ğ ãK qj ãĞHS /EGj û % #LĞRÊ û. Class45 KÎ NZzClass5 ĞHë&Ö ZMyBase BÎÛGÃ qêëeSystem.ObjectdDy 
o ãğj ãz KK{êZo Gc 4 j #KBĞxêö öYA OHfgMyBase 3DÃğ ÛClass4ĞAëZ gxDıKUMemberName ŞîMyBase.MemberName 
.MemberName 


Class Animal 
Public Overridable Sub ObtainLicense () 
Perform Animal-specific licensing code 


ERS SUS 
ERS CISSS 
CASS Cani mê 


Inherits Animal 
EUbIAE Over Fides SUG Ola inIMeense() 
Perform Canine-specific licensing code, then... 
" Cal lS COE LEOM Animal eElaSS 


MyBase.ObtainLicense () 
Ena SUD 
ERS Cass 


Ağrnlk QIR; acl ziconstructoryiî nöYî doîdaê È3 Gëe /OGKEA BEYE 
.Kqğ Şégarbage collection yA KO ne Rikğ A 3 Z AANOOGaestructor yArtadûê  qaictated 


28 BBS ÛÎ 3/0 Êê Ög ãد‎ % Kqğ ŞÊ ûf nÃxkB ãfimplicitt EP Şêxplicit 6G Aga nOg Ğ Öö dbf 


instance KBQ,ÖÖJ e ÖÖömemory space ay ngeserving Dg ÖhÛminimal constructor-level activities ÃÃ KëPzÊ n 
GBR Hf nörn doz kÖ FE ÊëK +ç È\ÛEÛ ABÛ xŠ zÖ/ ÜĞË dn.ğ AËÖ ŞÃövariable field 


@È/K* ãl Qaefault constructot FQ tö š4 ÃÖ QÛKÊ qğYnÃn çî ta. è +ê3mĞbÃÈ èÃ UL ÖÊ êèğãDFÊĞZ a َ 


BERBERA 3 Gk jr A 


êöêDÃË ök Kd Cnt #QÖOÎ ë 


Class Animal 
Public Name As String 


Public Sub New () 
Every animal must have some name. 


Name "John Doe of the Jungle" 


BRE SU 
End Class ي‎ e OS | 
ULString GEÃAêãdš YÊ Fj KEQı Ug Namek ê r ãOĞE A#Ê nk ë ãBÛ J zÖ/dêAnimal J ã¥ dıgRDZG§ Uonstructor Af ta e 
® Kt Feral têoH# Rê ya&¢@ rêrê È fx" Nothing r "aU Fel è Yö) Oê 5 Ağkteference typesGDÃt a 
ADEA ã ÛtêBÈŠS j EUX AKEOG ê? KO 


.ĞW' argument signature KÊ qğj YnÃn 3G AKÖ5ÃÊS5Ü' New ADEA &AÃ êA Û ö U ğãfî nKzzk3EÛ (ê Kk 


Class Animal 
EUOLLE NEMS AS SEEING 
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Public Sub New () 
کے کے ت اک‎ Every animal must have some name. 

Name = "John Doe of the Jungle" 

Ena SUD 
Public Sub New (ByVal startingName As String) 
e Use the caller-supplied name. 
Name = startingName 


Public Sub New (ByVal startingCode As Integer) 

Build a name from a numeric code.‏ چ یک 
Name = "Animal Number " & CStr (startingCode)‏ 

BAG SUS 

ERE CASS 


A rnÖö 5 B&FOBĞ ZA 
MsgBox ( (New Animal) .Name) 
' Displays "John Doe of the Jungle" 
MsgBox ( (New Animal ("Fido") ) .Name) 
BIS BLAViS RIO 
MsgBox ( (New Animal (5) ) .Name) 
1 Displays Animal Numoet OL 


dî BÛMoOQy EO KKŠ 3RVNMCGHEZ #Kkdnt? Fer aî tas bO akgO OU HÎ nyaÃ@ ã?% Ö¢Ğk ÖF(Ê n KDUBEÛ (Ê k 
CHEZ GF Fer ê tã Û dakê? YEO tãö fî t Dè oş X5 ĞBĞEÎ në /#êè r gD giOz Ê @Fz8ystem.Object Kb 
UF ã#QةOÖOÎ‎ ab / Kê ûãط‎ ÇÊ ĞX5ĞÃã 


Class Canine 
Inherits Animal 
Public Sub New () 
MyBase.New() ' Calls Animal.New( ) 
1 ج کے‎ Now add other code. 
MTC SUE) 
Ol CIA 


ÖYkdnšş ãZ#$ 5 ÜÖOÛÎ 3ÃKVËL Çê cA Z2 GF Gk r4 ùÎ kh tb ŞEY BCrZÊ kê EOHEGTKilling OR 
Ã bêrê 3 Z FAG KFıĞÈ r 3 BÛ # OR Z kê KÃ E NEL KEQ GAEš # ê dÖkB aOR ã 
.ĞÃ AON Hokans# êةz/ezqG‎ 4E 

Î r BÛÃAKBQ,3 zê Ekî KvkRZABEÛ (Ê kk kd. š% &Z#s Ğë KvkL Qê 4# öğ+ AA êz DÃAédOšx 


MVOC Nothing 


KBQëo&Z KA Zê Gî BÜîxyê gxbDZKÊ që 5 ÛKBQê < 


myDog = New Canine 
myDog.Name = "Fido" 
mMyBDog = New Canine 1 SOEEY Fldo, YOU EE Gone 


BEd CK ãGBOG UKE Z FT KBBgOOUZ GR 4 aËFinalizegÊ Ê rê A GR K où ŞÊSU3/KÊ Kkk.dağê KrkL QVhZES 
Z ĞÛN FBEûoverride ge gh OF DENY NEÃG r XE ëëSystem.Object Gh rotecteda GET GO Finalize AKL A 


.OQ¥ 
Class Animal 
Protected Overrides Sub Finalize () 
سے ی کے ہے کے‎ Cleanup code goes here. Be sure to call the 
' base GlasslSs HInalize MeENOG 
MyBase.Finalize () 
EMO SUS 
End Class 
Fr Ö5 HëR ü garbage collectionyÃ AEBS nie KiNG 3 doöÎDEFz(Finalize ONU BS î” 8 ÖDrÊ kKqğ yÊ ÜĞÛÎ tê 
G Aşg@ Öö gê qû ÖEOSA dè qêêrû êl EÛ (GX&GBĞYAÊ GÊ Oz, (3EGER @ RETA 


db JKOEGIOÎ tۈêÈ‎ OL RIOR T Fr DnéONÛ bö ê ê KöÈ ADHHOAFHAÊ A Kk. j AME <? ¥ O Fkk zêöo&e 
„ Örêtê ĞÊË ÈÊ Örıêb nÃRo yA êdmıé® Nj ŞUDZAOK, sd drito /ËEqj GEA GÊ ¥ dngë zêdo haê 13 
3 Şehê r Ö& yAÃ(Ê NK BBE KOHUÖOQHÖĞKO Arcleanup Z # Kî ĞA iZgĞOÎ tãî NKR bk 
ĞFDãğyZÃ (Ê KOR Ã n ĞKEĞÖNÛ & yZ# têdok iş. Šs&è êZAÖEÉ HOL9. GON Bb /KÈ O ? Ê AG § OÈ 
(Bëğr j KDFëoré o OÈ ).1Disposable 2 3/KkÖ; FBR ÛÖG@ doc 
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Class Animal 
Implements IDisposable 
BIOkEeCEed OvVEeEEIdeS SUG Einalize() 
ل‎ Cleanup code goes here. Be sure to call the 
' base class's Finalize method. 
MyBase.Finalize () 
ERE SUS 
Public Overloads Sub Dispose() Implements IDisposable.Dispose 
ص ا‎ Put cleanup code here. Also make these calls. 
MVEaSeE DISPOSED TT Only TE Base ClaSS 1S CISPOSAO le. 
System.GC.SuppressFinalize (Me) 
ERG SUD 
ERE CEE 


KOR zû KoDY &BŞ O dı ێة‎ Z r ÛÛ ez FH AK; HDispose eR Sê r SAME ÖĞş kê ^ 


Z ¥ KöëéKkĞOR. kçkê. giFë3Û Üng UsingÖÊ FbãDFÃğgIS yÃ¢@ ãdÖoKERZ(ĞKkFtã Gê Êê j ãdo»ÖAÖaEG; Ek 


O ta 
Using myPet As New Animal 
س ل‎ Code here uses myPet. 
End USING 
ص‎ AE EMIS BPOMME, MVECE 1S deSEEOVEd, and Di SPOSe 1S 
'" eEalled automat ieally Oy the End Using StlatemenE . 
GO taê Bdoğ J dA kOaêrdg GX AXBGIABdD, O A öR 3k? $ GOO ta) AAEA@MustlInherit ŞMustOverride GtDEêğjA OĞ 


ĞFDîëyãÃQ ãuşÖÃ zËÖN cx AşéöN Ö5 ÊšMustOverride yA kı MONöXE EĞER 3irP ik, Û 
FAK) E Êz definitions RNG Giainğ #zlabstract classes $k ğy#ËkInterfaces JF DFEës Kkinterface 
abstract kË Ğ UL Ù ڑz ئ‎ nG û kd) ÜOY BORD EGAS. Gg 3A0O 8 کک‎ 


Kê o ÜĞŠöÛBy convention A#ÖĞëËs K6ĞÊ KÃëinterfacegz KKEĞAE 3 Uk 


Interface IBuilding 
Function FloorArea() As Double 
SUb AlterEXE CEI OF () 

End Interface 


BÛ Ê KER Kk k ÖN 5 ÙÖÛÎ dB ĞFDŠR 3P Haz Kk kas ĞJÊ GĞÃÊ qê zorê KK. PkÃö‏ چ 
öR 3b R dy MOOR oA 5 ÛĞËzAÃ qérÃ/kö Kk È ÖzdÜh z 3 ÖÖöz KK{ëÃûè ÙÜÛzãzÛ nz Ay access modifiers‏ 
ğKDEeQ ãط 9Y WANOzŞstructures o alglblassesğ A? A Ünterfaces ğADğbventsq 3j Dpropertiesğ Ab Ã HDF‏ 
tû GX KBOTDEOR 5 KERÊ KL Q5 ÖOÖÎ & InheritsgîDãĞ: OãyaAÃG@ APA ihterfaces ğÃDğdointerfaces‏ ق 
BÛ KNĞk Ê 3 BÜB İkÎ ğ/ËڱÃk É Knãë¢@ ãl QgçîD#ãĞğ: YOĞãš@û ş Implements gD# ãğ YOğšyaÃ ¢ KëÃiğëğ A DZ&EÛ ãkÖöqdj‏ 
TDR 3‏ 


Class House 
TImplements IBuilding 
Public Function FloorArea() As Double Implements IBuilding.EloorArea 
جج‎ Add implementation here. 

Ema EURE EEO 

Public Sub PaintHouse () Implements IBuilding.AlterExterior 

Add implementation here.‏ جص 


nel CIS 
Z &Dtız Eza, Ûz F Ê KÖR; ö2fecky Ulin dK? BJD j ã6 DÊ 3 l ê ãş Az GEÛnKUĞTDğĞR 3j GBS Ak 
GONÎ ãyãÃ ê REZFÃAXKZAIterExterior zî HëdOxR DZEZ cöùz/Ötêç FëlL ë ã5 Ãg FloorArea KOBE Z.(GFDZã 
du30 tarOĞR Fek kw şPaintHouse 


Dim someHouse As New House 
Dim SomeBsua Ong AS BUI TORS 
someBuilding = someHouse 
someBuilding.AlterExterior() ' Calls someHouse.PaintHouse( ) 
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vok Ak, BÛ (Ê KY BA DBE 2? E DK doq Û gf ã& GXE/ GÉ do ğ Aie kı Oz 
Class House 
Tmplements IBuilding, IDisposable O N a o 
.GTDROGFHEHOLOR 3UMAY UD HAnGk <R 38Z 
EOI TE SUS EINE HOUSE () Implements USUI USING. ALECFEEXECETOE, TESMEEACEOE . DONO EK 
NE SUS 


GOR gADEAKRE A Dêya 405‏ ال Taeneric GA MR‏ فا KNÊ OY aR 23 êk a6 9 aA O Ö ARB‏ ت 


Ğz daî) YödDËğã ëêrönağÖ ko % ÖÖ OBFzÛDisposableĞFf DECAY KyÖÖ ر‎ È zEÃA#Ö nz Fî KD(ĞKè Zûê Mê 
mEAÃ) nê 


GA ê ÛÈT ر‎ ork dkë? ¥. modules 339 agzaptructures 63ê k 4® Z MKkg¥rOÊ baD AEA AAD UZA qe 


GO Fnku.iOuGA j h3n Rê &on.K SpA QA 72 Hë 
gzês ÃÖ QiĞÊËzĞZ. A qıûi KeğşöR sk .ÖFtf DOKÖKZ ğRëb fşûnÃ yè & KER ر‎ ên 13j3êÃxk 
Jaz Š dÊ nĞîşjÃËr3 Ok bÊ işe YQ» ÖRÊÃÃKÊ 3 ÖÖöĞÃ t®hared Dã Oã2nkiëaOrû 3ã 
Alok GE êzê het Kegşya¢ öuhe G û ŞG&# eg ONE & dnd nG eş BOF kG 3 


(j MaÃğš ék 6 

Friend Module GenericDataAndCode 
ےچ ی کے کے‎ ADEPT E AE OR GEODALE CONSE AME 
EUGINE Const AL UDG S AS SL EIN <S ULL OI 
ا‎ ABP IEA 1OR GI OBDaAL EUNCEION - 

BUGIIE EUNCEIOMN GelEMOCAIEADT GES NEYUSN SOUECES REIN AS SELIG) AS SEEING 

HERG BUNE E1 OM 
End Module 


r A QR 3ji RëëcG leşê ÛR zê Z û 33j KE2nÃ öşûf 1B êon hi öÃ BOG 
b Qy HOŞhNAÃ aAişğ KBQö s ŠÖ (kf 3B ITER 3P GÊ 3ê 7BR 3U aÃ¢@ + Gf 3BSTBk ê ö0 û ÃAŞĞšAD 
Z ÙÊÛyAÃKCÊ Nj Ğ Keéşz 3 Aûkat0 (Ê R.P ÛqualificationğjYLÜN f A ر‎ şéöêkÖkZ Ükö BÙ $X EB, rëfÃG ã 
٤ Private L8 ck GO (ier 3B 


ÖhDÊ êèRDHAĞR ze ã Ûy Û AE: ö O (KULŞ( System.ObjectdnEټ‎ NEBE) System.ValueType dopEO K 

30 (Ê kk ÛONK7nşëHëğr j öŠÃ ¢> yJÃ(Ê tayntax A6ÃëÈ ÃAqgaÃã ¢ eé #ëdoğ r j SA dBFÛ (Ê IgûntegerGrHÖ ãBZÊËĞ 

yr tall G6kZ constructor Af nk i R K30Ê Kã dob kê? BŞEĞ nÃ\ E6 KÖDaNB/ë ê E6 RES 6 KiyaÃ ¢ ã 
YeAfeKUdestructors 

Z ŠR 3j ãdnš Bİk tR KÛ (Ê KÛ Ê Gj AKKEt agp BDKê Mu UFzk qd > EBAEyHK@ & aslo KE kL NY BOON EÊ ë 

OFÊ î j ã5 Aj ÛR j ödndÖRÖc6K 


ûJêè ããã AêةROĞZ‎ Ğşkihnî A ÖÖÎ ak ûk ãj Kã Arg db ĞË L Ê k? % gOklÃk ãğ XÃĞozé K CG ÖÖ AëZ RÈ 
. code generatorsOĞ} #&n 
ÖZ. partial Form classtek ãğ dé KêĞË Z Öö&ê rk zDD? ¥ Jê CÊ | lg HÊ kAyxkzğkê ên UL EDK @ê baDFÃê 
Kd§b e¢êrtê: Kên KöĞÉÃk öj Ka KiBGA. 
KAK zkZ Aj Ödîlork akë? YĞOĞY ên. dû è ãağZA nãfÃ ¢ ãl QAoosÖÊ èbãDHÃĞZ gXDZPartial methodsĞk ãèÃd ã 
EÛAKêdÊ Hê BR BAMQ\r ã£Û Xã Fekezk?  gFOE(K B7SEA Adir GAO) UR gêrn Gy AAk/ES î A ÖÖÎ agûn: zÖÊ Mëe 
5 ÛÎ drt 
£ A FASE ãÖ/XÖر‎ ÛR ÛĞKEQN öèÃ0 ÎŠ xz / EBB ÃS UE ãèÃÛ ã zÖkı MOÖz 
Z KÃÖ Kërö ŠT AoptionalBQır ãimplemented half KZ O K2 )JŞunimplemented half CAXêKYZ Ö KğıSK DEFER ãةèÃl‎ 6 
Gri er3 YINE ROO tak ari FÊ Û Gê ãdüN ik 3K AV KÊ e 
AR tPartial gxD# 3 O&O tAKĞON Zz XK Crk 3N QAX ĞKZ û Zë 


Partial Private Sub ImplementlIfYouDare () 
HRC SUS 
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UËz ğÖÃĞFÈ sBÜJ Rê Private ê Xö FA G/N Gël Qy UËz ŞÛ unctionséoãğ ê Oka subt AikêÃ ãğÈ; ûk ÛEz Gk ã0 ã‏ ر 
ByRefgkD#ãĞ OÈ fŞêyVal grD# öĞ YOĞ#EĞ K‏ . 
cfÖz k ëYÛrËz ãrOĞ3n AD ZEYÊ İrêdmvdO' Partial lDEĞÖeÊ ã5 ÛkFŠöÖ ÖX%ëã5 MğãXinyENimplemented half GAXãz Ö #ë‏ 
jaws‏ 

Private Sub Implement IfYouDare () 

MSGBOxX (LT did TE, SO theEEe LL) 
HAGEL SUN 8 
EE CRE ELS ۸ ÜHOz AvoÃsy? dF qFODORKSBÈ OO; Q êd êê BA. 3nKOEOKKGErL MDD 
B Ké auto- -generated sideb ÙÖûöÎ art ÊÊ ã3 UEHOĞ# R têk ãN ã3 gk êda. Animal 
EAEEaAN Class Animal 


EUbITIE SUD Move () 
0 Interesting movement code, then... 


MoveSideEffects () 
mol SUS) 


End Class 


30E KOGEE RASD Az 0 KB UPA Ab GAlOhrside effects GED ake 1 moves OOZES J 6j ê e 


‘SD aU z.ĞH PrKQL CER ã 


b QdoALKBëZ Ö #ëı bş&Ö ik AÖ KãYö s ¢HÊÈ ÖÊ bğDFÃğL DÃQ, zê 0 Û 65 Az Ö KEÇKE E 5 ROA OR 
GO KéGSÊ ã) ã#êãĞk O&boş ãر‎ OÖtãz BOOT awek 
EARAN CLASS AMMA 


EUoIlAE SUB Move) 
ص ل‎ Interesting movement code, then... 


0 0ا‎ 
ERE CIASS 


ÊZABÃAKYêÈ Move K iëÖN EON a OTE TOM EO) AB BEEBE r ORAK rE Gk ö0 ãz Xk Û ê È 6 


ĞIKEZ Û ¢ êdndOqî A ÖÖ zBÛÎ ek 3n/Eê Kk ¥ BAR Ğ&R Fe ektA tûx Z or AnABÛOR AK EzkêgEbö QÛ 3ã 
® Ã oKÖKZ Ê XvÃG ke Atã 


DZMsgBox Gê Ka " Go &te éÖÖÎ Ööyêl YYeaG aD dni Öö Z kKXKXQZÃG êre! donb dK ¥ 
Ö@DEA6EYO j 6ة‎ qãZMsgBox GHÊëdnearryover KÛ' MsgBox Cê Këšay "Microsoft.VisualBasic SE ÛR Zz dn 
ãYda yÃÃ(Ê tãXîxıêÈBÜ5 KÎ NzOos&FKUFz.GHÖ ŞÛN êĞzÛg ĞDA + ã&ğ KD öĞ# Ê Q.ĞÛ FÊ ëêëê éz KkUFz.ÖÊ fe 
:5 Këxt 6K Msg BoxResultérëğëL Fe do ãYZÃAĞ 


EUOlIE HUNEETON MSIBOX (EYVA l1l BEOMBDE AS OB eeE, Ot IOoMal BVUal BUEEOMS AS MSITBOXSSEVIE > 

MsgBoxSTtyle. OkOnly, Optional ByVal TIElE As Object = Nothing) As MsgBoxResult 

PRU Eicons GOMlbuttons@BLD Buttons @ğ akî KkH6UÊ Kêk Ê aãz XK? Aatring GÉÃj GÊ ¥ê Prompt Ù fê zãÖO®N 

KkG HEBEKÊ Ê ã4 KÎ NTA HED O U gzRpak ÖOĞTitle J QKŞÊKZêû ËÈ $ yak@ Yö 
:5 KBÖÖoÎ &Z GHGã 

Dim resUll As MSGBOXReSULE  MSIBOxX (LIES Sate CO Click; the COMpUEeE WON expPlOde. lL, 

MSGEBOxXSEY Le, KeSNOCancel OE MSGBOXSEYLe OUesSEILOn, Click SomelhIinNnE) 


Click Something 


| 7 It's safe to click; fhe computer won't explode. 


rm EEE ۹ ETE 
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Ù Êz yÈ ÖÖî agAk&(Ê kzMicrosoft.VisualBasic ® ÛR z dnٍöŠDã dg GBKBdBA.DZÎDZ<Ok j Ãd@êl QMsgBox GÊ 


ĞEKê ULş MessageBox.ShowĞNÛ &AMãÖ/Êg Ûc#ãA UÊ ãZ k&ê ipa Ö3 Jods .ÖÊ bãDFÃĞ&ĞBÖdh 
.ĞÈ zÖfh zökê kk 5 KEĞKÊ BJ YnkirddOxiMsg BoxGHBOSLBLZEÊ o 


B.G زا‎ j KKEĞ Kink rŞ{hb/ë ر‎ Mz bêz ÛÖş ãû Ã FJÃËXKOYA Kdefers ODAAR gir BHO RKEgE A 
û Ã KÊ 3R ORÈ @EHÊ /R\(/E z GDA + ãozÛ RBI zz F ERE ORA ' bzÛÉ yÃÃ(Ê têÃÖoA A6; ãR Fë STEE 

. patient ÃŠÛĞ® /Y ÜÛĞ; ¢ êdn.yÃÃ(ê tãر‎ Î zU KD kê 

ê RHR G Rî Šö ê KEG a00) ON DO tada) l0 Refreshê KBDXO ĞÖRı db f (k(AFÊ ÃAqğŞtzÃĞ$)Ö Dêãëy? ¥ gS 
ÖÊ eaDFAĞdb R ik ã j AK ğAkKnö ö6 KDZ@ĞÖXy ÛÖn/Ã(Ê ndn AKER ' BAK Ö QKDaEĞ adê KãĞ Ã ã 
ê êzê Ak nz ûgêè êê inl qk erî 3 eQCKKêĞON &&Ö ر‎ CONE <2 Sh /#è û QAB DoEvents GNU ã 
gE HrëãĞ aط‎ KÎÛvyöê j oR Zz dnÜÖÎDBLDoEvents SORO &( screen updated Ã @BOXD)" paint "Ögê GO R QE 
j HÊ 

MS: CA O DOEVeENES Ol 
j #êdıK EGS ê ãZ /ëê oq /&ã zOÊÖÛFQ,ÖĞAÃ t &Û hOz{DÖZKÖ kùÛ Gy LhOzDoEvents of AMtayÃĞ f3 1 4 d8 


2 ¥ GhBÖÖ j ãkgêë Û êz &/ÊÈ ã QOMBÖöÛĞĞGAÃ t cê zk ê ZdngbÃrĞê Knğ&ê 3Û ÛrZ cenê ¢ ãl Qy Û Û ÖÖÎ ë 
5 


kandi KÊ êj YnAtêada šRUKK ER KAÇ ر‎ UD U3RÊ taxOĞRlbptional arguments GE qû Ynkin.dhO DO) HOE GOR BY Û 
ğYnÃtêãka Ù ê ak iêè x GEĞÃKËĞOê ¬ Ê Ak Oz Zz VÛN öĞkr ãêüKÊ êj Ynktêdnê{ K3 ĞA Ud 
f Ê qonAknyak ¢ RAMOS tãKOĞlL ê 3n iû nKEQrOĞ ÜRVALOzŞÜKÊ Këğ YnKtêë 28 KÊ ر‎ ERA 

ÎT ky ا‎ BRN GÊ Kê Ynktê3nÃ ÖşPa ay Ê KEONRtaRZA 3l parameter ا‎ argument) ê BGA n n 


AIF Ê #ëÖûktêL è ãöGParamarray gtDtãĞ: OBJ YnAtaĞzzÃAÖ t ĞKÊ KBğYnÃtêãyÃÃ (ê kéĞûR 
Public Function CalculateAverage (ByVal ParamArray sourceData() As Decimal) As Decimal 
جج‎ Calculate the average for a set of numbers. 
Dim singleVvalue As Decimal 


Dim runningTotal As Decimal = 0@ 

Tf (sourceData.GetLength (0) = 0) Then 
Return 0@ 

Else 


For Each singleVvalue In sourceData 
runningTotal += singleValue 
Next singleValue 
ReEUEN EUnNNInG NO Eal / SoUrceDaEa Cet LONGER (O) 
MIE UE 
OGL UMC ELO 


. decimalĞ FëL Öğdnšğ BÛÖO®' ¢talculateAverage GHÊ6Š$/#è r ã 
MSGBOX (EealceU la teAveEage (DT, 2S, A, SD DASS: © 


gê ComboBox FS gãfl istBox Gayê gry KÛ Ê Ê nêıoûmpıã t K êh.ÖÖ AğãA ëê z AN 
ğrRRObADDhODNaZ QHKoDAMPOVÃR têöhÃ ãia ênê 2Ù AK ê 


List Get Dê ر‎ RzAÖ rj K&R QComboBox #ÖAöèŞZÖ RListBox Ğ diBaŞ% ر‎ SUE êj #Ö qê 6ÛÊ baDÉ Z 

ĞÃ Ğ #RÊzÃÖ nk  ./ESÖOÖK z82 ĞËÊ GEA PGZÃ CÊ tã ItemData AKG) AKZO FEO êd QyAÃ(Ê R 
irs KnGkkY @RÛtemData/Zë) AëêzzÃAÖ n? % ÃÖÛ $É QVKk f 3têdıKDEdOx E6060 Aã YOY BUZ yJAÃÃ(Ê t ĞÊ Ke 
Ğ 3e #6 3ncekdk A 


cboMonth.AddItem ("January") 
cboMonth. ItemData (cboMonth.NewIndex) = 1 
cboMonth. AddItem ("February") 
cboMonth. ItemData (cboMonth.NewIndex) = 2 
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cboMonth. AddItem ("December") 
CSONMORE RTE emMDaE A KEBOMOR ERE NEE dexs) E 2 


PAE E O ks 3E; {U KEÇE RZ OHGKOUt XD s FEayaAG@ ãl Qy Morê HiBdn és fe yAÃ (ê têş ر‎ ËzûËbÃ É 


nMoREh = cboMonth. TEemData (CBOMontR. ListIndex) 


#SÃêêyZO ListBox Ğ HiBéa¥AÖ öK qı ŞÊë&ê Ù gkDtltemData AES RBS Fist Ğ Hido, ÖŠ ر‎ ÛĞÊ HR ã 

r8 Ak KIOBdovt zB Ã FAR3k ©. Items KBr AS BE DA) A7ZALÖŠ öoã&È ãZeditL gê öj ãdOĞ& ComboBox 
System.Object (Ğö§ JĞKÊ qolnٍÙ Öz 3 © šË GAR) ÜhdinĞ: kay dh AFDÃË,37Û (Ê ABA Öè Të BQ 

Z FARêo Kö3 DHEA yAÃ (Ê NEĞÃãèyZÖ EE collection 3 D@EëZ /EakY BU RHÖĞdovt zqBÜB? Ş 3Û (Ê @ Û 

. list 
" ToString Ö q5 ÛĞÖNO ëGË U2 kÊ êr QO di HOE /krdo,B} Ö Këö È FA ListBox Ğ: dii s KZ f 5 Kike 
BŠZAlistBox Ğ FE gêh R (kk Ã ãöĞk Zoverride E fê BÛ Ê System.Object Z GANT oString şa 


/FÈ KöÖ KEZEKY GÖ¢Gk Gê A {êz rè ş 3Û (Ê KY &" DisplayMember z7 3 ö6 "® Ã ã 
YaÃABÖR O 0 /ğ > Kt 5 KE&OĞZ ? UdnglzAZRDIstBox Ğ: ak a ZF FAKE aka 7A5 
EUDIME Class HOE 


Private Sub Form1_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) 
Handles MyBase. Load 

LiISEBOxXI .TEems . ACA) 

TiSEBOxX 1. TEems Add EASY) 


EÊ BOZ KETE , AO (S1200 
mel SUS) 
ENA Class 


.5 ABÖÖÎ BZ Aö JYaÃB6 ÃNEaÈ B&OĞ, Û5 ûr EKÖ (Bûd 


e 


Easy 
OSO 1427 


identifier s KtêÖoöj sÃAky RValueMember ® Ã ãistBox Ğ&3Bay% cêlbb f (UZÖîitem Data #6 AE fe OD. 
ok Z dd GQ ãğû Ê GaFÛ (Ê KA ö/ëR/alueMember yãÃ¢@ öةö6‎ È dx Items &Ağš3E OZ j RHOEODEnÊS A 
oaãDHEëĞÖN Z ر‎ ê AÖRÖöêBÛÖ: 3 zt ĞĞËöZ c(xL AKEUğÖ û Atê &Ö oYA dR 3HOqÛtems zAŠ3 © do/EËÛ ã 
dokB kui ù ÃFëgğÃ YDÈ On asî N30 (Ê FÛtems&Aë3 © Z lL Dj BËšesê asî 34Û (Ê kÖdîh ?A Û dÖxsÖÊ Fe 
Kod YEO 3 3Û (Ê Kk 
¥ Ù Û db zt ĞZrrÃŠj qR qêdoK&XëztzComboBox FSÃvè% qUistBox aay Z JYDÊ BÖ»Š ds ? ÖGdO& 
Ö Fëğ eê #koRuĞÛ rÊ aêğ öÃ gb ADA L 3 êêê nz cé ê kiç AKêgEÊêZ QUĞ ¥Oö enëã¢ ãûDs #tã 
.iHDEKO B KFA AER 
Add Gz? Üš RM ÛeProject tg nérî dmugAbDZÃk Zz Zz? Ûğë î A 6 GO /QHUB4Ö têxOğۍZ‎ hız EÊ 6 
5 ÛÖÛÎ ë5 AëxOĞÎŠT ê .AddA ÛRERÖR List/ltemData.vb Z KöbğÈ .Class 


EUDLLE Class LSE ITteMDaA Ea 
ERA Class 

aû şit JURay#û DisplayMember ĞÖ Ã BÛD KšÖöj Öù <ÃKÊ qj Z.Ö pasê KOR 3Ü Öz ĞA&KA dR ÇÈ 
&FORZ? yê ÜÖÛÎ zëR 3Qînitialization D § ã% qãÖ: WBKRÖ Ö U Af nT oString GAS Oge gê RZ A FSAÃã 


‘Hêk Ê a 5B KË 
PUDINE CLASS MISELECMDAE A 
Public Itemlexl As StrEing 
Public ItemData As Integer 


Public Sub New (ByVal displayText As String, ByVal itemID As Integer) 
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چ‎ Initialize the record. 

ItemText = displayText 

ItemData = itemID 
0 


EFublie Overrides EUnet ION TOStEEINI() AS SEEING 

Display the basic item text. 
Return ItemText 

HHA HURE EAON 


PUbliEG Overrides Eunction Equals (EYVal Obj As Object) As BOOlean 
کو‎ Allow IndexOf () and Contains () searches by ItemData. 
If (TypeOof obj Is Integer) Then 


Return CBool (CInt (obj) = ItemData) 
Else 

Return MyBase.Equals (obj) 
End FEE 


ENA RUNEENON 


EMA CASS 


têl Eo BşêÃ qada. yaãÃ ¢ ã3Û (Ê qpistBox ĞFKK çK 3 ABs /Ëek 
Li SE BOX E TEemMS ASE NE SEI ECEMA Ea E TEEemM TEE 2)) 


3 Og û GER rj hr yêÃ ¢ Azê AG UB êb DÊ KOR URE GÊ ÖH@Ëquals GO Bye gb ÛYGAN 
A ğêkyãî) êz cê AqoÖğEad ¢ GRO BAG. Ea ten &FKY GîindexOf SON Ed Ê QĞ JE gË Items GAR 
ğ raf rue ãğû ëBZKAfrê o /ÉË #quals &Öş ListBoxĞ #Bay® Z BR DIKÊ Š ak É د‎ KEizÛistltemData GS 

BA Gk FDERÊ 3 3ME (kinteger value QE Fe 


Dim itemPosition As Integer = SomeListBox. Items. IndexOf (5) 


ComboBox Ga | e ÖY'na O ãdo_ KË qz Kêr Dtêt t j AKG GAS 2? ¥ AE 3 MES GaKEOÖ ABB ÛgxHûke 
oş ãzl. o XT oÃš öRKOD ig o2 KE(kA,ãšêğ YDÈ Br{D§ (Code JBÊEz(Ê nj zOköoë ãdû. 3P .EKÛ ĞëZ Û FÊ ë 
.GEDtêcollections ğAtoz GEE E CE EEE 
Description Type 
Primary key; automatically assigned. Required. j Long - Auto 
. مفتاح رئيسي»آلي الإسناد. مطلوب‎ 
Name of this status entry. Required. Text(50) FullName 
. اسم مدخلة الحالة.مطلوب‎ 
ÖnÃ /Fëkl kÖ kak tadb 2 - G¢@ êorÖzêdn. ASUUgaRD š FtêOĞJ - EKÊ KBE Aq NÖUê ê ÛÛOÎ ebê êdê 3P ر‎ Ûh 
derived versions ĞÎ mNÊ qöYA dn, ûvÖësÃ.AxÛ KL qÛ BO XEÇEëG Fiv( Gk {EXE yaz kç @ .ÖŞÊ ê. QONXEUbYAÃ (Ê 1 
BEES dk KEG do 
GÊ B®)" detailû® AKS GR êGAt6j ã3 G3 û AVBKR" summaryÖÛ Ãûašaek DëyZ Ê A Û tãdODUn. 
Ö AtãšdyZ Ã§j ãn B/ëkÖDÈ gên UA 7BÛ Ö ÃÇëÛ Ûz db A JÊ E: vies î j ê. (Bin ADAKDEL KO O/XEl@e 
"detail Od AG šêrZ NT ¢ ROB è PXEOSAS BBKOĞL T Hn'summary 


Ãö ĞKëÖ 3Ö1 ãKUş BaseCodeForm.vb ca New Windows Form/ADÃY™ šéy<Project t Nt têb ÙRDZid&rZ? Û 


BaseCodeForm (Name) 
FixedDialog 
406, 173 


Code Form 


ĞhÃ ãyaÃğëga. do.ğ+ Aj öÃ qè KORO: Hda( CodeqOB<View ö BJET B4Ö taOĞb bd zBdodOO) ¢ 
.Mustinherit gxD# ãĞ YOĞ&K t GÖĞaşAÃ /Bûinstantiation Nê AB3P 3%? ¥ O KÖKEÊÈ BG. 


Public MustInherit Class BaseCodeForm 
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BARoĞğQY DBTAGEOOFT ãZ  UhxDErğYDÈ BJKDEL ğYDÊ öOKERYXDKGê ğjYDê ĞA Û zûê yzAĞÊ FKëçtã 
dorî FEF ãUÃFéS zêÖ Ö ÃAÇëS Aj #& SAME Rr ?Ãğ 4ö dO&RMustOverride Z 3% zB@4. OF, BÛ (Ê QYSBY AEA b34 
BE REOÃ &é /& 


Public Overridable Function AddRecord() As Integer 
ڪڪ ل‎ Prompt to add a new record. Return the ID 
1 when added, or -1 if cancelled. 
Ret Urn Zl 
EMS EUT 


Public Overridable Function EditRecord (ByVal recordID As Integer) As Integer 
1 E Prompt the user to edit the record. Return the 
: TECSEILS MD ME Saved, Or MM OM CARES. 
EEE US 
EDO HODE E SOD 
"ببنودها. نحتاج لطريقتين ون أجل معالجة‎ 51١٣١2۲7۷ ستأخذ فئة "التفاصيل اذهاعل " مسؤولية ولء أداة صندوق القائهة ×180ء1]على فورم "الملخص‎ 
هذا:واحدة تعول على إضافة جميع البنودءوأخرى تحدث بند وحيد.ستكون الفئة المشتقة ضرورية لدعم هذه الميزات.‎ 


Return the formatted name of a single record.‏ کک ا 
Public MustOverride Function FormatRecordName (ByVal recordID As Integer) As String‏ 


بجب أن تعرض أيضاً فورم "التفاصيل" العنوان ومعلومات الاستخدام الوناسبة على نووخج "الملخص ". 


a ReLUEn the ttle Bar text EOE ENIS CEQdIEOEFE. 
Public MustOverride Function GetEditTitle() As String 
على الرغم من أن معظم الجداول ستوفر قائمة قصيرة بالأكواد المرتبة أبجديا.بعض الجداول ستتضمن عدد كبير(ربما الآلاف)من الأكواد.ستدعم‎ 
طريقة بحث.لإيجاد كود موجود بسرعة.بما أن النماذج المشتقة الخاصة ستستخدم هذه الميزة. فلن نضمن‎ " 51١۳3۲۷ فورم "الملخص‎ 
.MustOverride 
Public Overridable Sub SearchForRecord (ByRef destLlList As ListBox, ByRef exceededMatches As Boolean) 
ج ي‎ PrEempE the User to search EOE a ECCOEM. 
Return 
إا ل‎ 
أخيراء ستشير فورم التفاصيل إلى آيا من الميزات المتاحة التي يمكن استخدامها من فورم "الملخص".وستستدعي نموذج الملخص كل من الدوال‎ 


Public Overridable Function CanUserEdit () As Boolean 
Check the security of the user to see 
١ E COAMEINS 1S aL OWES 
Return False 

otel OMG 1O 


Publi Overridable Function UsesSearch () AS Boolean 
کے ل‎ Does this editor support searching? 
Return False 
EDE URGE TOR 
.فيما بعد ف هذا الكتاب. سنعمل على إنشاء إصدارات مشتقة لكل جدول كود‎ ener deأةأا‎ ٥۲٣ هذا کل ما تحتاجه فورم التفاصيل الشاملة‎ 
.code tables 
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Mhm76 ا الثامن:الفئات والوراثة.‎ 
Sr dvg aûCKÊ qî yA (Ê KKEz ÊKA .Û Ûz Û rÊ 4z dg gi KEfaê ãšdt Kd OROSZÊ ê5 Ãêyaz 
cB öo/ğùistEditRecords.vb ca şE@ dok kA ö ya A6/RDZiderzZ ÛyAÃ (Ê ËYÖã OGDEN, Ab ÖHŞ6OS AG 
5 KëÖÖÛÎ &Z K Gz Aö ŞEQOHUÖ 3Ö1 ãR Fë 


d3 eS aRUDEGDESEP ŞAHÊ ¥ Gî U YaÃABl T FngListBox Gay îl 


RecordsList 


لسجلات الصعحروضةل+) 


%4 É K GûxOBz Û F AAS taÖEڱ‎ ÛR 


EEUOUNES CLASS MES EEOALE RECS SUS 
Private DetailEditor As Library.BaseCodeForm 


Public Sub ManageRecords (ByRef UseDetail As Library.BaseCodeForm) 
جص ل‎ Se Up EhNe EOEM EOE Use MIEN EMIS EOE SEE. 
Dim exceededMatches As Boolean 


Delan lEdIEOE — USeDeE A1 
ReCOEdASIAElLE. lexSE — DeEANIEQTEOE GEEEJUE Ele (0) 
RecordsInfo.Text = DetailEditor.GetEditDescription () 
Me.Text = DetailEditor.GetEditTitle () 
ActAdd.Visible = DetailEditor.CanUserAdd () 
NEEEGLE VISIBLE — Dela ULEIIEOE . CAnNUSEEEA LE () 
ActDelete.Visible = DetailEditor.CanUserDelete () 
ActLlLookup.Visible = DetailEditor.UsesSearch () 
DetailEditor.FillListWithRecords (RecordsList, exceededMatches) 
RefreshItemCount (exceededMatches) 
Me.ShowDialog () 

e 

Private Sub RefreshButtons () 
ل‎ Update the buttons as needed. 
ActEdit.Enabled = CBool (RecordsList.SelectedIndex <> -1) 
ActDelete.Enabled = CBool (RecordsList.SelectedIndex <> -1) 


Private Sub RefreshItemCount (ByVal exceededMatches As Boolean) 
If (exceededMatches) Then 
RESTEECOLUDNEL LEXE RESUL ES lIMICEd EO AES CL & 
RecordsList.Items.Count & " items" 
Elself (RecordsList.Items.Count = 1) Then 
ResultCount.Text = "1 record displayed" 


Else 
ResultCount.Text = RecordsLlList.Items.Count & " records displayed" 
MOS ME 
ENA SUS 
Private Sub ActClose_Click (ByVal sender As System.Object, ByVal e As System.EventArgs) Handles 
ActClose.Click 
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19 


Mhm76 الفصل التامن:الفئات والوراثة.‎ 
ت‎ Enable controls as needed. 
RefreshButtons () 
End SUS 
Private Sub RecordsList_DoubleClick (ByVal sender As Object, ByVal e As System.EventArgs) 
Handles RecordsLlList.DoubleClick 
0 _ Same as the edit button. 
TE (ACEESN E ViSMG LSE — Tele) IMEeN ACEECA E. ECEESEMCLT CE 0) 


Private Sub RecordsList_SelectedIndexChanged (ByVal sender As System.Object, ByVal e As 
System.EventArgs) Handles RecordsList.SelectedIndexChanged 

Enable controls as needed.‏ ا 

RefreshButtons () 
EMA SUS 
End Class 


.(yaÃABT CGÈ aya ÃğÛ#Ke LAKES ¥ RÖMÃ HÛ KF dnm® A Go s FKrsA têakOÖş ãÊ ã 
Br ivale Delal I EINES AS MDEOSEY BASE COIEE OEM 
. ManageRecords Gê RA 4 ËrT Nk qãÖĞ§BaseCodeForm yzÃëdmw Û nê GS S Ã5 ÖÖzêğL 


e 0 ,ManageRecords (ByRef UWSEDE AN AS Library. BaseCodeForm) 


3% qê QAA.ĞÖ) têBaseCodeForm sdrdmgéa Fx Gj Z &ş ManageRecords U3/KÊ /NBE&OĞR) ÜPKÖÛNÎ aaa. E 3D 
GRÖÃ$ Oê 2 8." summaryÛ Ãkašaey? ¥ û AHO KEE q GK OYA Ea KOByAÃ Ê KbDetailEditorth BOO BÛ 
U3/KÊ K'"ActAdd Ğ&Ê ÛR" visible UY ® A 3# Boolean Avtzqob kin: Kek 3/k¥ RCanUserAdd "detail O AG šer 


GON Bo KK #röyYXÊKGER Fel; 3 terDZr&Ö Ğ& fe BüëstBox 'ÖÛ ÃAëšdey UGE illListWithRecords SONO ã 
.yAÃ(Ê E Û Ã¥ãyzz Me.ShowDialog 
2 8 .DetailEditor BÛÖÖ EAS Ûr@ KrùDÃËkğ ãğ ãA bT nı 0ا‎ Ã¥ã Sy? Jêğ 3m OAGÊ yAÃÇÊ tûy hok dên B 
& #rêraûj OND dmÃBUĞ: Frr'Ö AãšégZ &OĞAddRecord Oê AES ĞOR 5 EÛAãL T rÖDZIêAÃ ÛR ŠğÃşöÛKÈ 
® Aã 
Private Sub ActAdd_ Click (ByVal sender As System.Object, ByVal e As System.EventArgs) Handles 
ACEAGdA. CUT Eek 
جح ا‎ Let the user add a record. 


Dim newID As Integer 
Dim newPosition As Integer 


Prompt the user. 
newID = DetailEditor.AddRecord () 
If (newID = -1) Then Return 


Add EhiS EecOEd to the laisSC.‏ ص ل 

newPosition = RecordsList. Items.Add ( (New Library.ListItemData( _ 
DetailEditor.FormatRecordName (newID), newID) )) 

RecordsList.SelectedIndex = newPosition 

RefreshButtons () 

RefreshItemCount (False) 

End Sub 


ÖgAik? $ £ Qtão KÛ fî AğenğÃ@ ã QglDHERs Fa O XEBE WrLODNT cê nh Aã šderZ UÖRêkOĞL T in 
O ABZ AR oV OSYGBoO ABZ KORO 3 FAOOADE 7Z 2 ¥$ OO HbRORGGD adn. 4ê iD.dê.yaÃAB3r.yÃÃ (Ê tû 
U3 OOF KOBE Pê EAE KA 
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الفصل التاسع:البرمجة الوظيفية. Mhm76‏ 
البرمجة الوظيفية Functional Programming‏ 

في هذا الفصل سنغطي موضوعي برمجة رئيسين في الفيجوال بيسك:تعابير الوسيط (لامداجل اه ]ا )و معالجة الأخطاءوہ هم۸2 ٠/٣٥١‏ .وكلاهما غامض »الأول 

بسبب استخدامه الحرف الإغريقي في اسمه والأخر لأنه بالإضافة لكونه بالإغريقي فهو صعب بالنسبة لكل المبرمجين.يجب أن يتم عمل تعابير الوسيط لامدا بمبداً 

شامل للبر مجة الو ظيفيةو ١١9/2٥۲م ٣2/‏ ٥ء‏ ءالفكرة هي أن كل مهمة معالجة يمكن أن يتم التعبير عنها كدالة(وظيفة)وتلك الدالة يمكن أن يتم تمريرها طوعا 

أو كر ها رااا-راااس ضمن الكود المصدري. 

الفيجوال بيسك ليست لغة برمجة وظيفية (برمجة بالدوال) حقيقيةءولكن تقديم تعابير الوسيط لامدا هلط وإفي الفيجوال بيسك2008 يجلب للغة بعض هذه الطرق 

الوظيفية والوسائل. 


يتم تسمية تعابير الوسيط لامدا لحسابات لامداو/ں/وء و۵ط”4/ (أر وںاناهء-.۸)ءنظام رياضي تم تصميمه في 1930sبواسطة‏ ألونزو كارك ۸٥٣20۵‏ 
Church‏ »على الرغم من أن عمله كان في البداية نظرياءفإنه قاد إلى ميزات وتراكيب تفيد معظم لغات البرمجة اليوم. على وجه التخصيص»توفر حسابات لامدا 
الأساس المنطقي ءاه هاو لدوال الفيجوال بيسكءمزاعمں؟ »و المعاملاتءا هيوه ءوالقيم المعادة sمں‏ اج۷ ناه التي درسناها سابقا.لذلك ما الفائدة من 
إضافة ميزة جديدة للفيجوال بسك وتسميتها ولط ه| بما أن أشياء الوسيط لامدا موجودة في اللغة؟سؤال عظيم »ولكن لاجواب. 

تتيح لك تعابير لامدا من تعريف كائن ما يحتوي على دالة كاملة.على الرغم من أن هذا نوعاً ما شيء جديد في الفيجوال بيسك.فميزة مشابهة قد كانت موجودة في لغة 
البيسك ٥|8۸5ولفترة‏ طويلة.وقد وجدت صيغة يدوية قديمة من لغة البرمجة الأقدم التي استخدمتها5 ل۴1 8۸51٥‏ ءفكانت توفر العبارة 0۴ التي تتيح لك تعريف 
دوال بسيطة.إليك بعض مثال الكود من تلك والتي تطبع قائمة من خمس تربيعات 


T00? DEE (SOR(X) = X * XxX) 
LOS e E => U Mo 

120 BEINIEL, SORO) 
OE Next I 

AME End 


يظهر تعريف الوظيفة(الدالة)في السطر100ءتعود بمربع أي معامل نسبي ممرر لها.وتستخدمه في النصف الثاني في السطر120ءمولدة المخرجات التالية: 


تعمل تعبيرات لامدا في الفيجوال بيسك بطريقة مشابهةءتتيح لك تعريف متغير كدالة بسيطة.إليك مكافئ الفيجوال بيسك من أجل الكود السابق: 
Dim sqr As Func(Of Integer, Integer) = Function(x As Integer) x * x‏ 
For i As Integer = 1 To 5‏ 
MsgBox(i & vbTab & saqr (i) )‏ 
Next i‏ 
تعبير لامدا الفعلى فى السطر الثانى: 
Function (x As Integer) E U SC‏ 
تبداً تعابير لامدا بالكلمة المحجوزةمناممں۴ »متبو عة بقائمة المعاملات النسبية الممررة داخلها 0-١‏ مءءهم ضمن أقواس.بعد ذلك يأتي تعريف الدالة نفسهاءيستخدم 
تعبير ما €[ المعاملات الممررة داخليا لتوليد نتيجة ما نهائية.في هذه الحالة النتيجة هي قيمة ×مضروبة بنفسها. 
شيء ما لن تراه في تعبير لامدا وهو عبارة .Re†u r‏ عوضا عنه» تبدو القيمة الراجعة واقعة خارج نطاق التعبير بطبيعة الحال.وهذا لما تحتاج نوع ما من متغير لحفظ 
التعريف 0۸ااہاfملوالراجع‏ ۸اه والنتيجة اناوه في تركيب مشابه لدالة. 
Dim sqr As Func (Of Integer, Integer)‏ 
يتم تعريف متغيرات تعبير لامدا باستخدام الكلمة المحجوزةءہں۴ .تطابق قائمة نوع بيانات المعامل النسبي قائمة المعاملات النسبية لتعبير لامدا الفعلي»ولكن مع نوع 
بيانات إضافي ملقی في النهاية Integer‏ والذدي يمٿل نوع بيانات القيمة العائدة,إليك تعبير لامدا الذي يتفحص فيما إذا يعمل معامل نسبي عددي صحیح وم١۱‏ 
على إرجاع أو عدم إرجاع نتيجة منطقية اهمع . 
Public Sub TestNumber ()‏ 


Dim IsEven As Func (Of Integer, Boolean) = Function (x As Integer) (x Mod 2) = 0 
MSGBOx (TIS 5S Evens " & TlSEvVeN(S)) 
End SUB 


يعرض هذا الكود رسالة تقول"هل يقبل5القسمة على 2؟خطأ"خلف المشهدءتولد الفيجوال بيسك دالة فعليةءوتربطها بالمتغير الذي يستخدم التفويض(التفويض كما 
تتذكر» هو أسلوب لتعين طريقة ما وبشكل عام من خلال متغير متمايز) الكود التالي هو حقيقة ما يولده المترجم من أجل عينة الكود السابق. 
Private Function HiddenFunction1l (ByVal x As Integer) As Boolean‏ 
Return (x Mod 2) = 0‏ 
ERS HUREEIOR‏ 
Private Delegate Function HiddenDelegate1l (ByVal x As Integer) As Boolean‏ 
Public Sub TestNumber ()‏ 
Dim IsEven As HiddenDelegatel = AddressOf HiddenFunctionl‏ 
MsgBox ("Is 5 Even? " & IsEven (5) )‏ 
End Sub‏ 


في هذا الكودءتعبير لامدا والمتغير مه۷ عءاالمتعلق به قد تم تبديلهما بدالة حقيقية( 1 ٥iاء 10de ۴ un‏ )وتفويض و سيط( 2e1‏ وهاه2"٥ل١١).‏ على الرغم من أن 
الوسائط لامدا جديدة في الفيجوال بيسك2008ءفإن هذا النوع من التخصص الوظيفي المكافئ قد أصبح ممكنا منذ نسخة الفيجوال بيسك الأولى للدوت نت.توفر تعابير 
لامدا أبسط تركيب عندما تعمل الدالة المرجعية التفويض ١0ااء”u؟ ٠٤٥d‏ ءrء؟ءء-مatومامd‏ على إرجاع النتيجة من التعبير فقط. 


الفصل التاسع:البرمجة الوظيفية. Mhm76‏ 

لقد تم إضافة تعابير لامدا للفيجوال بيسك2008 بشكل رئيسي لدعم التخصص الوظيفي الجديد لينكو(الفصل17).وهي مفيدة بشكل خاص عندما تحتاج لتوفير تعبير ما 
كقاعدة(قانون) معالجة كود أخرءوخاصة الكود المكتوب بواسطة المشارك الثالث(عامل أجنبي).وفي تطبيقاتنا الخاصةءالمشارك الثالث(العامل الأجنبي ) هو 
میکروسوفت. 


تعابير لامدا جيدة »ولكن من الواضح أن تخصص وظيفي مكافئ كان موجود سابقا في اللغة.وبنفسها تعابير لامدا هي فقط تبسيط لتركيب تفويض- دالة ١-‏ 0ں 
egate‌اەلغیر‏ مرتب(فوضوي).ولکن عندما تضم تعابیر لامدا مع میزات استنتاج الن وع ٥۲٥۸٤٥‏ ممرئ فسوف تحصل على شيء ما أفضل.ما تحصل عليه 
بالأنواع المستنتجة هو تعابير لامدا.وهذا ليس اسما رومانسياءولكنه أداة عظيمة جديدة.لنقول أنك أردت كتابة تعبير لامدا يعمل على ضرب عددين ببعضهما. 
Dim mult As Func (Of Integer, Integer, Integer) = Function(x As Integer, y As Integer) x * y‏ 
MSsGBOX (MULES, GO) DiS AaYS 0‏ 


إن هذا نقل لقالب كبير من الكود:إني أخبر الفيجوال بيسك كل شيء »وهي تطيعني بدون تردد. ولكن توجد أيضا ترجمة أكثر حرية ٠ه‏ zهوواه|‏ للكود الذي يجلب 
استنتاج النوع ضمن التشغيل. 

im mul > HUNEEION (xX AS IMtegder, VY AS Integer) x 1 VY 
هذا كود أقل بكثير .لقد تعبت من كتابة /عوعاہ/مرة بعد مرة.يعمل الكود لأن الفيجوال بيسك نظر إلی ما ھو مسند ل {اںم‌وبشکل مناسب عین(حدد)نوع بیاناته‎ 
(شاهد الشكل التالي).وحتى أنه وبشكل مناسب خمن النوع الراجع(المعاد).‎ Function) Integer, اnteger)‎ As القوية.وفي هذه الحالةء tاںم هو من نو ع موماہ!‎ 


Dim mult = Functionlx As Integer, YF As [Integer] xX " YF 


Dim mult ûs #Function(lnteger, Integer] &z Integer 
يفترض أنك قد وضعت "خيار الاستنتاجه؟١| هنام "ل"فعال "0 " في كودك المصدري »أو من خلال صفحات خاصیات المشرو عsعااممہام ctمزہPr (وھو‎ 
الافتراضي).نستطيع اختصار تعریف ااام‌حتی لاکثر من ذلك.‎ 
Di MOLE = SUNELIOM C, WY < 3F 


في هذا السطر سيستنتج الفيجوال بيسك نفس الدالةءولكنه سيستخدم نوع بيانات الكائن †ءهزط0 على طول محل العددي الصحيحهوه۲,| .أيضاءإذا كان لديك "خيار 
التدقيق اء S٣‏ هم0 "وقد تم وضعه إلى"فعالم0 "(والذي يجب عليك)»فهذا السطر لن يتم ترجمته حتى تضيف شرط و۸ المناسب. 


داخلياءيعمل الفيجوال بيسك على تغيير تعبير لامدا إلى "شجرة تعبير "أي تركيب هرمي يجعل العوامل ءلمهإممم مصاحبة لمعاملاتهاءإهاج ممه .خذ هذا التعبير 
الشبه معقد الذي يرفع تعبير مضروب إلى قوة. 

n CAlOULEESNE = MCE, My, 2Y) CS MM) 
يولد الفيجوال بيسك شجرة تعبير للمتغير {اعاهاںماهعوالذي يبدو كما في الشكل التالي.‎ 


عندما يحين وقت استخدام تعبير لامداءيدور الفيجوال بيسك على الشجرةء»يحسب القيم من المستويات الأدنى إلى الأعلى.ويتم تخزين شجرات التعبير هذه ككائنات 
معتمدة شل فئات في فضاء أسماء lhl. System.Lingq.Expressions‏ كنت لا تحب كتابة تعابیر لامداءبامكانك بناء شجرات تعبيرك الخاصة باستخدام هذه الكائنات. 
ومهما يكن»لن أخوض بهذا الموضوع. 
الوسيطات مدا lلnعiدdasö Complex Lab‏ 
على الرغم من أن تعابير لامدا لايمكن أن تحتوي عبارات فيجوال بيسك مثل الحلقات)×ه۴0۲...۸ ءمايزال بإمكانك بناء بحعض الحسابات المعقدة نوعا ما باستخدام 
معاملات قياسية. الاستدعاءات الخارجية للدوال يمكن أيضا أن تظهر في الوسيطات لامدا.في عينة الكود التالي يؤجل اام عمله لدالة؛ارام Mu‏ . 
Private Sub DoSomeMultiplication ()‏ 
Dim mult  EUnNGCEI1OM (x< AS Integer, V AS Integer) MUILIpIVIE (x, VV) 1 10‏ 
MSEBOX MULE OS, OD DISPLAYS 40‏ 
End Sub‏ 
BUDE BUNE ODN MULE ENBYVaAL K ZS Ite GeR, BVIal VY AS InNCegeE) AG INCegGeR‏ 
REE WEN xX SV‏ 
ERA EUMCEEA OM‏ 
هذا بسيط جدا.ولكن تحصل أشياء أكثر أهمية عندما يكون لديك تعابير لامدا تعود بتعابير لامدا أخرى.تم اختراع حسابات لامدا بشكل جزئي لرؤية كيف يمكن أن يتم 
تقسيم دالة معقدة في عدة دوال أكثر بساطة.وحتى القيم الحرفية(المحرفية) يمكن أن يتم تعريفها كوسيطات لامدا.إليك تعبير لامدا يعود دائما بالقيمة3. 


الفصل التاسع:البرمجة الوظيفية. Mhm76‏ 
Dim CMEeE  EMCEION (O) 3‏ 
لقد رأيت منذ حين تعابير لامدا التي تقبل أكثر من معامل نسبي: 
DAM MU NE ٠ ٠‏ 


Function (x As Integer, y As Integer) x * y 

في حسابات لامداءيمكن أن يتم تقسيم هذا إلى دوال ابسطحيث كل منها يتضمن فقط معامل نسبي وحيد. 

Dam mU NEZ Function (x As Integer) Function (y As Integer) x * y 
نوع بیانات 2اا ںہ لیس نفس نوع بیانات 1٤ں ٬ولکن کلاھما یولد نفس الجواب من نفس قیم ×ورر .عندما تستخدم1٤اںم »فإنه یحسب الناتج ل رو رویعود به.وعندما‎ 
»فإنه يشغل أو لا الجزء (۲موهاہ! ك4 »)هنام ۴ءوالذي يعود ب لامدا أخر محسوب بتمرير قيمة برفي تعريفه.إذا مررت فيه "5" كقيمة لمر ءفإن لامدا‎ مںا٤2مدختست‎ 
Function (y As Integer) 5 * jy:يھ المعادة‎ 
و لامدا هذا يتم حسابه»والناتج من 5و رريتم إعادته.واستدعاء 12ا في الكود أيضاً مختلف قليلا .فلا تمرر في المعاملين النسبيين في نفس الوقت.بدل ذلكءتمرر في‎ 
المعامل النسبي لأجل »ومن ثم تمرر رل لامدا الأولي المعاد به.‎ 

MsgBox (mult2 (5) (6)) 

عندما تشغيل الجز ء(2)5٤اںم‏ ءيتم تبديله ب لامدا المعاد أولا.ومن ثم لامدا المعاد أولا يتم معالجته باستخدام(6) كمعامله النسبيمر .ليس هذا بالبسيط؟. 
الجزء الهام الذي يجب تذكره هو أنه من الممكن بناء تعابير لامدا معقدة صعوداً من تعابير لامدا الأساسية(القاعدية). ستستخدم الفيجوال بيسك هذه الحقيقة عند توليد 
كود من أجل التعابير المتعلقة بلينكو NQ‏ |1 .وسنتحدث عنها في الفصل 17ءوحتى ذلك الحينءستدير الفيجوال بيسك الكثير من تعابير لمدا التي تركز على لينكو 
1|۵ من أجلك خلف المشهد(غير مرئية). 


على الرغم من أنك تستطيع تمرير معاملات نسبية ضمن تعبير لمداءمن المحتمل أيضا أن تستخدم متغيرات أخرى ضمن مجال تعبير لمدا. 
Private Sub NameMyChild()‏ 
Dim nameLlogic = GetChildNamingLogic ()‏ 


MsgBox (nameLogic ("John")) ' Displays: Johnson 

End Sub 

E ZEEE MOLE LON CSE LEONE me LOG AE J AS UME (OE SEO, SEMO 
Dim namesUfElx AS StEING = "SON" 


Dim newLlLogic = Function (baseName As String) baseName & nameSuffix 
Return newLogic 
ERS HURME EIS 


تعود الدالة ءiوماومص‏ ه١‏ 0لاااCاهم6بتعبير‏ لمدا.وتعبير لمدا ذاك يتم استخدامه في الطريفةهاا ٣٣ر‏ هه" بتمرير ٣۸‏ هلكمعامل نسبي ل لامدا. وهو يعمل»ولكن 
السؤال كيف. المشكلة هي ×اff‏ 8ه همءالمستخدم في منطق تعبير لمدا»وهو متغير محلي ضمن الطريقَةّءاوماوما"ه ١اا‏ ٥ه6‏ .جميع المتغيرات المحلية يتم 
تدمير ها عندما تخر ج الطريقة.في الوقت الذي يتم فيه استدعاء الدالة×0 8وو" ءسيكون ×اا 5م" هقد انتهى منذ وقت.ولكن مايزال الكود يعمل وكأن ×اf؟ںSم "a۳‏ 
مستمر .لجعل هذا الكود يعمل ءتستخدم الفيجوال بيسك ميزة جديدة تدعى رفع المتغير وہ/١// 2/2/٥‏ .رؤية ×ااSufهمصهمسيتم‏ الوصول له من خارج نطاق(مدى) 
Naming logic‏ ¥ اetchiع.تعيد‏ الفيجوال بيسك كتابة كودك المصدري»تعدل متغير محلي إلى متغير له مدى أوسعهمهءء wide‏ . 

في النسخة الجديدة من الكود المصدري»تضيف الفيجوال بيسك فئة الإغلاق(النهايتوووإء مuوم/ء‏ ):الفئة المولدة بشكل ديناميكي والتي تحتوي على كل من تعبير 
لامدا والمتغيرات المحلية المستخدمة بواسطة التعبير. عندما تضمهما مع بعضهما البعض»فأي كود يتمكن من الوصول لتعبير لمدا ستكون له أيضا إمكانية الوصول 


للمتغير المحلي. 
Private Sub NameMyChild()‏ 
Dim nameLlogic = GetChildNamingLogic ()‏ 
MsgBox (nameLogic ("John")) ' Displays: Johnson‏ 
ENA SUB‏ 
Public Class GeneratedClosureClass‏ 
BUL Ne! names tIxX AS SCE < LEONE‏ 
Public newLogic As Func (Of String, String) = Function (baseName As String) baseName & Me.nameSuffix‏ 
End Class‏ 


Per valte HURE On GeSCRI I ONamınOLOIIE N) AS HunEeNOE SECIRG, SELIRG) 
Dim localClosure As New GeneratedClosureClass 
localClosure.nameSuffix = "son" 
Return localClosure.newLogic 
End Function 
الكود الحقيقي المولد بواسطة الفيجوال بيسك هو أكثر تعقيداً من هذاءوسيتضمن كل كود التحويل تفويض-دالة الذي كتبت حوله سابقا.ولكن هذه هي الفكرة الأساسية.‎ 
فئات الإغلاق ورفع (ترقية)المتغير هي ميزات أساسية لتعابير لمدا بما أنك لا تعرف أين مكان تعابير لامدا على الإطلاق.‎ 


للبدء»ان خاصيات الكائن object properties‏ غير مدارة بواسطة المشيدات٬تحتاج‏ لإسناد هذه الخاصيات بشكل منفصل بعد إنشاء حالة فئة مباشرة. 
Dim newHire As New Employee‏ 
newHire.Name = "John Doe"‏ 
newHire.HireDate = #2/27/2008#‏ 
newHire.Salary = 50000@‏ 
توفر العبارة ۷)۸تركيب أفضل نوعا ما. 
Dim newHire As New Employee‏ 
With newHire‏ 
.Name = "John Doe"‏ 
.HireDate = #2/271/2008¥#‏ 
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.Salary = 50000@‏ 


End With 
.) تم في الفيجوال بيسك2008 تضمين بناء ×هارءجديد يتيح لك دمج التصريح(بالكلمة المحجوزة»ه" )وإسناد الأعضاء.يتضمن البناء تنوع جديد لعبارة‎ 
Dim newHire As New Employee With {.Name = "John Doe", .HireDate = #2/27/2008#, .Salary = 50000€} 


تصحيح ومعالجة الأخطاء هما اثنان من معظم نشاطات البرمجة الأساسية التي تقوم بها في أي وقت.حتى في التطبيق الخالي التصحيح»يوجد دائما سبب للاعتقاد بأن 
المستخدم سيفقد أشياء غاية في الأهميةءعملك أن تكون حارس على بيانات المستخدم عند إدارتها بواسطة المستخدم»ولحفظها آمنة»حتى من تهاون المستخدم نفسه 
وحتى من قبل كودك المصدري نفسه.إن أكثر من %50 من الكود يكون محجوز لمعالجة الأخطاءءالبيانات السيئةءاستثناءات النظام»والإخفاقات »بشكل مركزي»كل 
هذا الكود الإضافي يبطى التطبيق ويضيف الكثير من التكاليف غير المباشرة لما تم تسميته "البرمجيات المنتفخةمaسههاط‏ ". 


سوف تتعامل مع ثلاث تصنيفات رئيسية للأخطاء في تطبيقات الفيجوال بيسك: 


بعض الأخطاء هي واضحة (صريحة) جد بحيث أن الفيجوال بيسك سوف ترفض ترجمة تطبيقك. بشكل عام»بعض الأخطاء تنتمي لقضايا بنائية بسيطة والتي يمكن أن 
يتم تصحيحها بعدة ضربات مفاتيح.ولكن تستطيع أيضا تمكين ميزات في برنامجك التي تزيد عدد الأخطاء المميزة من قبل المترجم. على سبيل المثال»إذا وضعت خيار 
التدقيق Option Strict‏ ل"فعال On‏ " في تطبيقك أو ملف الكود المصدريءفإن تحویلات التضييق ستولد أخطاء وقت الترجمة. 
BN 2 OPEN SEEN OM‏ سس ١‏ 
Dim bigData As Long = 5&‏ 
Dim smallData As Integer‏ 
mm The next line will not compile.‏ 
smallData = bigData‏ 
تتضمن الفيجوال أستودير 2008 الميزات التي تساعدك في إيجاد وحل أخطاء وقت قت الترجمة.مثل هذه الأخطاء تم تعليمها ب"بخط أزرق متعر جا ووsqui blue‏ ' 
د د ا د هو مبين فى الشكل. 


1j Option Strict On 

20 Public Class Forml 

3 Frivate Sub Buttonl_Click|ByVal sender As System. ûOhject, BFVal e As System. EventArgs) Handles Buttonl.ClicF 
3 

5 Dim bigDPata As Long = 5&4 

Dim samallDPata As Integer‏ ه 

2 The next line vill not compile. 

3 amallData = bhigqpata 

End Sub ES‏ ا 

Option Strict On disallows implicit conyersions from‏ ا 
"Long" to "Integer'.‏ ;11 


# | Replace 'bigÛ ata" with 'ClntlbigO ataj'. 
Dim smallData As Integer 
9 eas Ths next line will not coupiles 
smallData = CInt fbigDat a) bigate 
End Sub 
End Class 
4 آآآآآ‎ [ *ً 


| E»pand dll Previews 


تحدث أخطاء وقت التنفيذ عندما يسبب جمع(تركيب) من بيانات وكود شرط غير صحيح فيما يظهر من كود على أنه صحيح(محقق).مثل هذه الأخطاء تحدث 
باستمرار عندما يدخل المستخدم بيانات غير صحيحة في التطبيق»ولكن كودك الخاص يمكن أن يولد أخطاء وقت التنفيذ.خذ المقطع التالي من الكود: 
Public Function GetNumber () As Integer‏ 
Prompt the user for a number.‏ ج ا 
Return zero if the user clicks Cancel.‏ ' 
Dim useAmount As String‏ 
InputBox returns a string with whatever‏ ا م ا 
the user types in.‏ ' 
useAmount = InputBox ("Enter number.”")‏ 
If (IsNumeric (useAmount) = True) Then‏ 
Convert to an integer and return it.‏ .© 
Return CInt (useAmount)‏ 
Else‏ 
a Invalid data. Return zero.‏ 
Return 0‏ 
End Tf‏ 
ERO HUNG I OT‏ 


يبدو هذا الكود معقول لحد ماءوفي معظم الحالات»هو كذلك. فهو يطلب من المستخدم عدد ماء»ویحول أعداد صحيحة لتنسيق عددي صحيح»ويعود بالنتيجة.الدالة 
ume‏ لءاتجتث (تستأصل)أي مدخلات غير عددية غير صحيحة.استدعاء لهذه الدالة سيعود بالحقيقة بأعداد صحيحة محققة للقيم العددية المدخلةءو0 للمدخلات غير 
الصحيحة. 


2 
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ولكن ماذا إذا ما تم إدخال قيمة مثل"342304923940234"وبما أنها قيمة عددية محققةءفسیتم تمریر ھا للدالة امہ ں ۸ ءاولكن بما نها تتجاوز حجم نوع بيانات 

العددي الصحيح»ءفإنها ستولد خطأً وقت التنفيذ كما هو مبين في الشكل التالي. 
= 


Form 


Loankinue, the application will ignore this error and attempt to continue, 


Unhandled exception has occurred in ¥our application, IF ¥ouı click. 
ال‎ IF ¥ou click Quik, the application will close immediately, 


Arithmetic operation resulted in an overflow, 


Continue | qu 


بدون كود إضافي لمعالجة الأخطاء أو يتفحص حدود البيانات المحققة(الصحيحة)ءفإن الروتين ١ط"‏ ١اهBسيولد‏ خطأً وقت التنفيذ هذاءومن ثم يؤدي إلى إجهاض 
كامل البرنامج. 


الأخطاء المنطقية هي الثالثة»وهي أكثر أنواع الأخطاء انتشاراً.المتسبب بها هو أنتءالمبرمج»لاتستطيع لوم المستخدم على هذه الأخطاء.من قضايا سياق المعالجة إلى 
الحسابات غير الصحيحةءالأخطاء المنطقية هي لوح تطوير البرمجيات وللحصول على نتيجة تحتاج إلى وقت أكثر للتصحيح من كلا النوعين السابقين مع بعضهما. 
تم تخصيص الكثير للأخطاء المنطقية في هذا الكتاب.تستطيع أن تجبر العديد من الأخطاء المنطقية خارج نطاق كودك بإضافة اختبارات كافية للبيانات الغير 
صحيحة»وبشكل مناسب اختبار تطبيقك تحت شروط وظروف متنوعة. 

لن يكون لديك الكثير من الصعوبة في التعامل مع أخطاء وقت الترجمةوإت٣۲م compile-time‏ .ھم عام لمبادئ البرمجة في الدوت نت والفيجوال بيسك»واستخدام 
نظامي للأدوات المضمنة مع الفيجوال أستوديو2008ءسيساعدك في سرعة إيجاد والتخلص من هذه الأخطاءrs compile-time erro‏ . 

القضية الأكبر هي:ماذا تعمل بخصوص أخطاء وقت التنفيذ؟حتى ولو تفحصت كل البيانات الممكنة وشروط المصادر الخارجيةءمن المحتمل أن تمنع جميع أخطاء 
وقت التنفيذ.لن تعلم أبداً متى ستفشل عملية الاتصال بالانترنت»أو يخطىئ المستخدم في كبل الطابعةءأو خدش على ديفيدي 0۷0سيعطي بيانات فاسدة. 

في أي وقت تتعامل مع المصادر الموجودة خارج كودك المصدريءفستكون لديك فرصة أكبر لحدوث أخطاء وقت التنفيذ. 

يبين الشكل السابق ما تعمل الفيجوال بيسك عندما تصادف خطاً وقت التنفيذ:فهي تعرض للمستخدم حوار خطاً شامل»وتوفر فرصة لتجاهل الخطأ(من المحتمل فساد أي 
من البيانات الغير محفوظة)أو الخروج من البرنامج مباشرة(فقدان كامل للبيانات الغير محفوظة). 

على الرغم من أن هذين الفعليين يتركان للمستخدم الكثير من السحرءولكن لا يعطيان طابع الثقة للمستهلك في مهارتك بكتابة الكود.إن المستخدم سيلومك لأي أخطاء 
تنتج بواسطة تطبيقك»وحتى لو كانت المشكلة الحقيقية قد تم إزالتها تماما من كودك. 

لحسن الحظتتضمن الفيجوال بيسك ثلاث أدوات لمساعدتك في التعامل بالكامل مع أخطاء وقت التنفيذءإذا حدثت وعندما تحدث هذه الأخطاء. هذه الميزات الثلاث 
للفيجوال بيسك :معالجة الأخطاء غير التر كيبيةوہناك 2 unstructured e٣0۲‏ »معالجة الأخطاء التركيبيةوہاك structured erro ٣a٣‏ »ومعالجة الأخطاء الغير 
معالجةوہiا١ error a٣‏ edاunhand‏ .يمكن أن يتم استخدام كل من هذه الثلاث في تطبيق الفيجوال بيسك لمنع بيانات المستخدم-والمستخدم نفسه- من أخطاء غير 
مراده. 


لقد أصبحت معالجة الأخطاء الغير تركيبية جزء من الفيجوال البيسك منذ الظهور الأول في عام1990.وهو سهل الاستخدامءياتقط كل الأخطاء الممكنة في مقطع من 
كود»ويمكن تمكينه أو تعطيله حسب الحاجة.بشكل افتراضي»لاتتضمن إجراءات الطرق والخصائص أي معالجة للأخطاء على الإطلاقءلذلك عليك إضافة كود معالج 
الخطأ-التركيبي والغير تركيبي لكل إجراء حيثما تحس أن هناك حاجة له. 
الفكرة التي تقع خلف معالجة الأخطاء الغير تركيبية هي إلى حدما أساسية.ببساطة تضيف سطر في كودك يقول"إذا حدث أي خطأ بأي حال»اقفز بشكل مؤقت إلى هذا 
المقطع الآخر من إجرائي حيث لدي كود خاص للتعامل معه. هذا"المقطع الآخر" يدعی" لج الخطÎ error hand|er‏ ". 
PUBL IGE SUS EEO EE ONEROUEINEN)‏ 
Any code you put here before enabling the‏ ص ا 
error handler should be pretty resistant to‏ ' 
runtime eFEOFS‏ ' 
Turn on the error handler.‏ کک 
On ErrOo GOO EEEOEHaAnNdLER‏ 


More code here with the risk of runtime errors.‏ جڪ ل 
When all logic is complete, exit the routine.‏ ' 
Return‏ 
ErrorHandler:‏ 
When an error occurs, the code temporarily jumps‏ ھ ٣‏ 


" down here, where you can deal with it. When you're 
' finished, call this statement: 
Resume 
جک ا‎ which will jump back to the code that caused 
' the error. The "Resume" statement has a few 
1 var laeions available. TE VOU QonlE want EO GO 
1 Baek to Main COde, SUE JUSE WANE EO GEE OUE OE 
" ERAS EOUE Ine 4S GUIeRlyY 4S BOSSE, Gal lS 
Return 
ENG SUS 
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تمكن عبار ة On Error‏ أو تعطل معالجة الخطاً في الإجراء. عندما يحدث ظا ماءتضع الفيجوال بيسك تفاصيل ذلك الخطاً في کائن خظا شاملاcھزاo global Err‏ . 
وهذا الكائن يخزن نص وصفي للخطآ(الكود العددي للخطأ (إذا كان ممكنا))أو تفاصيل مساعدة عبر الانترنت فيما يتعلق بالموضوعءوقيم أخطاء نوعية.وسأجدول 
التفاصيل بعد قليل. 
تستطیع تضمین العدید من عبارات ۴۲۲٥۲‏ 0 في كودك كما تريد.وكل واحدة يمكن أن توجه كود منحرف إلى رقعة (عنوان)مختلف.يمكن أن يكون لديك معالج خطاً 
وحيد لأخطاء الشبكةءوواحد خاص بأخطاء الملفات »وواحد لأخطاء الحساب»وهكذا .أو من المحتمل أن يكون لديك معالج خطاً كبير والذي يستخدم عبارات 
۴...٣... e‏ لتفحص شرط الخطاً المخزن في کائن الخطأ lErrشlمobjectJ global Err‏ . 
ErrorHandler:‏ 
If (Err.Number = 5) Then‏ 
ez2 Handle error-code-5 issues here.‏ 
تستطيع إيجاد أرقام الأخطاء من أجل الأخطاء المشتركة في مستندات الفيجوال أستوديوءولكنها معتمدة على أعداد مكتوبة بدقة وغير قابلة للتغير تجعل معالجة 
الأخطاء الغير تركيبية أقل انتشاراً في هذه الأيام مما كانت عليه قبل الدوت نت. لايهم دائما ما الذي سبب الخطأ. أحياناء إذا عملت على تمكين معالجة الخطاً حيث كان 
علي أن لا أمكنه فهذه ليست نهاية العالم»فيما لو وصل الإجراء للنهاية في مسألة تحرير الخطأءببساطة أقوم بالتبليغ عن تفاصیل الخطأ للمستخدم»وأتجاوز سطر 
التوجيه. 
Public Sub DoSomeWork ()‏ 
On Eritor COOLS BEEOLHARNILEE‏ 
Logic code goes here.‏ س ل 


Return 
Er rOEHandIl er; 
MSGEBOX (SAN CEEOr COCCUEEEA IM DolheNWOLK E € EET DeSCEI C1 OM) 
Kesume Nextê 
Enda Sub 


يبلغ مقطع الكود هذا عن الخطأ»ومن ثم یستخدم العبار Resume Nex‏ (تنوع للعبارة القياسية gal(Resumeدة‏ بسطر الكود مباشرة للسطر الذي يلي السطر الذي 
سبب الخطأً.يوجد خيار أخر يستخدم (تابع"من عنوان أخر "امطها_۲مطام_مmمء‏ مصuءهR‏ )والتي تعود بالتحكم لمنطقة معينة من الكود من خلال مناطق نوعية 

3 
مسما 


استخدام العبارة On Error GoTo‏ یمگن من معالجة خطا معین کی الرغم من اناك تستطیع استخدام عبارة On Error GoTo‏ تانية لإعادة ت دوجیه اللأخطاء لمعالج خطاً 
أخر في إجرائك٬الحد‏ الأعلى الذي يبقى خلاله معالج خطاً واحد ساري المفعول هو أي وقت.فحالما تفعل(تمگن)معالج خطاً ماءفإنه يبقى ساري المفعول حتى نهاية 
الإجراءءأو تعيد توجيه الأخطاء لمعالج أخر »أو تخصص تبديل إلى غير فعال ۴ه م ں) لمعالجة الخطاً في الروتين(الإجراء).ليأخذ هذا الأخير دوره»أصدر العبارة 
التالية: O» Bio: Colo O‏ 


لايعمل معالج خطأً أي شيء خاص.خذ مقطع معالجة الخطاً التالي: 
ErrorHandler: ٠‏ 
Resume Next‏ 


عندما يحدث خطأ ماءفهذا المعالج يرجع التحكم مباشرة للسطر الذي يلي السطر الذي سبب الخطأً تماما.تتضمن الفيجوال بيسك اختصار لهذا الفعل. 

mM ZEKE MESS NEE 
بإصدار العبارة.فإن جميع الأخطاء ستقطن في كائن الخطأ(كما يتم عمله مع جميع الأخطاءءلامشكلة في كيفية معالجتها)ومن تم يتجاوز السطر الذي سبب الخطأً.ولم‎ 
يتم إعلام المستخدم عن الخطأءوسيستمر في استخدام التطبيق مع تجاهل الأخطاء‎ 


كانت معالجة الأخطاء الغير تركيبية مجرد طريقة لمعالجة الأخطاء المتاحة في الفيجوال بيسك قبل الدوت نت.وعلى الرغم من ذلك فقد كانت سهلة الاستخدام»وهي لا 
تفي بالمتطلبات المفرطة بخصوص إعلان الإصدار 2002 للفيجوال بيسك دوت نت أنه نظام برمجة كائنية التوجه.وهكذاءعملت ميكروسوفت على إضافة معالجة 
الأخطاء التر كيبية وم/ااف 2ط ۲٠٣۲ع‏ ۵ءء للغةءوهي طريقة تستخدم كائنات قياسية للاتصال بالأخطاء»وكود معالجة الخطأً الذي يكون أكثر تكاملا بإحكام مع 
الكود الذي يعرضه. 

تستخدم هذه الصيغة من معالجة الأخطاء عبlرة Try...Catch...Finally‏ المتعددة الأسطر لالتقاط ومعالجة الأخطام 


١ Add error-prone code here. 
Catch ex As Exception 

Error-handling code here.‏ ا 
Ema NIY‏ 

١ Cleanup code goes here. 


تم تصميم عبارة ر۲ لعرض مقطع أصغر من الكود.وتستطيع أيضاً وضع ج جميع الكود المصدري لإجراء ما ضمن مقطع »وهو أكثر ما يكون مشهور بوضع 
ضمن ذلك المقطع فقط العبارات التي من المحتمل أن تسبب أخطاء. 
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العبارات الآمنة يمكن أن تبقى خارج نطاق الحصة رم ۲لعبارةر۲ "٩‏ ۴...ر٣٣‏ .ما يشكل عبارة برمجية آمنة بالضبط هو الموضوع الكثير المناقشة.ولكن نوعين من 
العبارات هي بشكل عام غير آمنة©1)تلك العبارات التي تتفاعل مع أنظمة خارجيةءمثل ملفات قرص »أو شبكة أو مصادر الأجهزة المركبة على الكمبيوتر »أو حتى 
المقاطع الكبيرة من الذاكرةءو(2)تلك العبارات التي يمكن أن تؤدي بمتغير ما أو تعبير لأن يتجاوز الحدود المصممة لنوع بيانات ما لذلك المتغير أو التعبير. 


يعرف الشرط ١ءاهمعالج‏ خطأً.وكما مع معالجة الخطأ الغير تركيبيءتستطيع تضمين معالج خطاً شامل في عبارةرم] »أو تستطيع تضمين معالجات متعددة لأنواع 
مختلفة من الأخطاء.وكل معالج يتضمن الكلمة المحجوزة Catch‏ الخاصة به. 
CEC x AS BETOCLASS‏ 
المعرف ×ھ يوفر اسم متغير ما لتفعيل کائن الخطا الذي تستطيع استخدامه ضمن مقطع۸ع اه٥‏ .تستطيع منحه أي اسم ترید»وقد يتفاوت من شرط لاخر ›ولکن لیں 
عليه أن يكون كذلك. 
تطابق و5ه!ا٣٤‏ ۲٥٣٣ع‏ فئة الاستثناء "هنام هع ×ه :فئة خاصة مصممة بشكل خاص لنقل معلومات الخطأ.فئة الاستثناء الأكثر شمولية هي ۸ هنام م٥×۴."هاءرS»ويوجد‏ 
فئات استتناء آخرى أكثر خصوصية تشتق من الفئة ہام م٥×۴.‏ اور بما أن العبارۃ ر٣٣ ...٤٥۵‏ ر٣٣‏ تنفذ"'معالجة موجهة بالکائنات orںrإض object-oriented‏ 
rocessin9م‏ "فان جمیع الأخطاء يجب أن يتم تخزينها ككائنات.يتضمن إطار عمل الدوت نت العديد من فئات الاستثناء المسبقة التعريف تم اشتقاقها سابقا من الفئة 
System .Exception‏ والتي تستطيع استخدامها في تطبيقك. علی سبیل المثال؛ هنام 6ء× 0م4۵87 .9i۷‏ "هاور تلتقط أي خطأ ينشأً (بوضو ح) عن تقسيم عدد ما 
TEY‏ 
result = firstNumber / secondNumber‏ 
Catch ex As System.DivideByZeroException‏ 
MsgBox ("Divide by zero error.")‏ 
Catch ex As System. OverflowException‏ 
MsgBox ("Divide resulting in an overflow.")‏ 
Catch ex As System.Exception‏ 
MsgBox ("Some other error OCCUErEd.")‏ 
EDS TEY‏ 


عندما يحدث خطاً ماءيختبر كودك الاستثناء مقابل كل تعبير ۸ع1ه0حتى يجد الفئة المطابقة.يتم تفحص التعابير 6۸هعبالترتيب من الأعلى إلى الأسفلءلذلك تأكد من 
وضع الأكثر عمومية في الأخير »إذا وضعت في البدايةہ هنام مء×۴. "هاور ءفإن ولا تعبير من تعابير ۸ء)هالأخرى في مقطع رم۲سيتم إطلاقه أبدا لأن كل استثناء 
یتطابق معہه‌اامه٥×٤.”هاءرS‏ .إن عدد شروط ١۸ءهعالتي‏ تضمنهاءأو أي استثناءات و هنامهء×ه تعرضهاء يعود إليك.إذا تركت جميع تعابير ءاه فارغةءفإنها 
ستتصرف نوعا ما مثل العبار On Error Resume Nex5‏ »و اذا ما دت خطا ماءفان جمیع العبارات المتبقية في مقطع ۷ سیتم تجاوزها.وسیتابع التنفيذ بالمقطع 
ااه" ۴»ومن تم مع الكود الذي يلي كامل عبارة ر٣‏ . 


يمثل الشرط رااه٣۴جزء‏ من مقطع ر ٣الذي‏ يقول"اعمل هذا أو مت".إذا ما حدث خطاً ما في عبارةرم] ءفإن الكود في مقطع رااه ز۴ سيتم تنفيذه دائما بعد أن يتم 
اكتمال عبارة ۸ءهعالمناسبة (ذات الصلة).إذا لم يحدث خطأءفإن المقطع رااه۴سيبقى قيد المعالجة قبل مغادرة العبارةرم٣‏ .إذا أصدرت العبارة ٢إ Ru‏ في مكان 
ما في عبارة ry‏ ءكذلك سیبقی المقطع yااجہ‏ ۴ قيد المعالجة قبل مغادرة الروتين(الإجراء).إذا استخدمت العبارة Exit Try‏ للخروج من مقطع yمبكراًءفإن‏ المقطع 
ااه ز۴كذلك سيبقى قيد المعالجة.إذاءبينما يكون مقطع ر٣٣قيد‏ المعالجةءفإن مقطع رااج۴سيبقى أيضا قيد المعالجة. 

الشروط رااه ۴هي اختياريةءلذلك فإنك تضمن فقط شرط رااهز۴واحد عند الحاجة له.الوقت الوحيد الذي تحتاج فيه لشرط رااهہ :۴هو عندما تزيل كل شروط 
Catch‏ في عبارة 1۲y‏ . 


لقد بينت لك سابقا في هذا الفصل كيف يمكن للأخطاء الغير معالجة للبيانات الفاسدة أن تقود لانهيار التطبيقات»أو مسارات حلزونية.جميع المبرمجين الجيدين يفهمون 
أهمية كود معالجة الأخطاء»ويقومون بعمل جهد إضافي لتضمين إما كود معالجة الأخطاء التركيبية أو الغير تركيبية.من المحتمل أن تفكر أن إجراء ما لا يعمل شيء 
قد يؤدي إلى توليد أخطاء.وسأتركه بدون كود معالجة الخطاً وبالتالي أوفر بعض الوقت في كتابة الكود. هذا ما يخطر ببالك»وبوضوح وبدون أي إنذار:يظهر خطأ ماء 
وینهار! 
عادة»جميع الأخطاء الغير معالجة تظهر تراكم الاستدعاءءتبحث عن الإجراء الذي يتضمن كود معالجة الخطأ. على سبيل المتال»خذ الكود التالي: 
Private Sub Level1 ()‏ 
On HE EOS COLO BE ESEH ANGLE‏ 
Level2 ()‏ 
Return‏ 
ErrorHandler:‏ 
MSGBOX ( EEEOE Handled. 1)‏ 
EELS MESE‏ 
ENE SUS‏ 
Private Sub Level2 ()‏ 
Level3 ()‏ 
ale SUNS‏ 
Private Sub Level3 ()‏ 
The Err.Raise method forces an‏ ےک ا 
URNS EEUCEUEEd SEVE SEEOE‏ ' 
Err.Raise (1)‏ 
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عندما يحدث خطا في المستوى13ءيبحث التطبيق عن معالج الخطا الفعال في الإجراءءولكن لايجد شيء.لذلك»وبشكل مباشر يخرج من المستوى13 ويعود إلى 
المستو 12ءحيث يبحث مره أخرى عن معالج الخطا الفعال.مثل هذا البحثءبكل أسىءسيكون عديم الفائدة.ويدمي القلب»يغادر الكود المستوى12 ونتقل عائدا إلى 
المستوى 11ء ويتابع بحنه ل معالج حدث معقول. و هذه المرة سیجد واحد.تقفز المعالجة مباشرة الخ مقطع معالج الخطاً ErrorHandlerو‏ تنفذ الكود في ذلك المقطع. 
إذا كان المستوى11 ليس فيه معالج خطأءولايوجد كود يشير إلى التراكم المتضمن على معالج خطأءفإن المستخدم سيرى نافذة رسالة الخطأ البائسة(راجع الشكل 
السابق)ءمتبو عة بموت البرنامج المخيبةا "6" †”oiمDisap‏ . 
لحسن الحظ تعمل الفيجوال بيسك على دعم معالج خطأ"التقط الكل|اج۸ءجع "والذي يصطاد مثل هذه الاستثناءات الغير مدارة ويتيح لك فعل شيء ما 
بخصوصها.و هذه الميزة تعمل فقط إذا كان لديك حقل"تمکين إطار عمل التطبیق o a٣٥ W0)‏ icatiاممa‏ ماnabع‏ "وقد تم اختیاره في تبویب التطبیق 
icationاApp‏ لصفحات خاصيات المشرو عءعااهمهآم أءعزه۲م .للوصول لقالب كود معالج الأخطاء الشاملءانقر زر "عرض أحداث التطبيJ View Application‏ 
۷5ع "على نفس تبويب خاصيات المشرو ع.اختر "(أحداث تطبيقي‌ءاہ ٥۷ع‏ ١0ااهءiاممMyA‏ ")من اسم الفنة مه ووو|ع للقائمة المنسدلة فوق نافذة الكود 
المصدري»ءومن تم اختر 0۸م xceعedاnhandلمن‏ قائمة اسم الطريقةم٣ Na‏ ١٥طه"‏ .يظهر الإجراء التالي في نافذة الكود: 

Erivatê SUS MYASPINEaAEIOnNn URNRERII edEXEEDETON (EYVA Sender AS Oo ecE, BVUal € 2S 


Microsoft.VisualBasic.ApplicationServices.UnhandledExceptionEventArgs) Handles Me.UnhandledException 
End SUS 


أضف كود معالجة الخطأ الشامل في هذا الروتين.يتضمن المعامل النسبي م عضو الاستثناء والذي يوفر الوصول لتفاصيل الخطأ بو اسطة کائنہ ٥م System.Exce‏ . 
إن عضو ۸٥ناھ»‌iام‌م۴×14.ه‏ هو خاصية منطقية 4٠ا٥‏ 80والتي تستطيع تعديلها إما للاستمرار أو للخروج من التطبيق.بشكل افتراضيءيتم وضعها إلى 
صواب»ولذلك عدلها إذا كنت تريد الحفاظ على البرنامج مشتغل. 

حتى عندما يبقى البرنامج مشتغلءفإنك ستفقد مسار الحدث النشيط(الفعال)الذي أطلق الخطاً.إذا ظهر الخطأ(أتى) من النقر على زر ما من قبل المستخدم» فإن حدث نقر 
الزر بالكامل»وكل طرق استدعاءه»سيتم هجر هالمم م لوطه مباشرةٌ وسينتظر البرنامج لإدخال جديد من قبل المستخدم. 


توجد أشياء أخرى تدور حول الأخطاء يجب أن تتعرف عليها في برامج الفيجوال بيسك. 


صدق أو لاتصدق»توجد حالات من المحتمل أنك تريد فيها توليد أخطاء وقت التنفيذ في كودك.في الحقيقةءالعديد من أخطاء وقت التنفيذ التي تصادفها في كودك تحدث 
بسبب أن ميكروسوفت كتبت كود في مكتبات إطار العمل (ءا٣۴) Liba‏ assاC‏ meworkو۴r‏ التي تنتج أخطاء بشكل خاص.وهذا تصميمي. 
لنقول أن لديك خاصية لفئة والتي تقبل فقط قيم النسب المئوية من 0 إلى100ءولكن كنوع بيانات عددية صحيحة. 
Private StoredPercent As Integer‏ 
Public Property InEffectPercent (J) As Integer‏ 
Ge‏ 
Me CUED SEOESEGEGE CONE‏ 
End Get‏ 
Set (ByVal value As Integer)‏ 
SEOTECIECCENE = ale‏ 
End Se‏ 
End Broperty‏ 
قواعديا لايوجد شيء خطأ في هذا الكود»ولكنه لن يمنع أي شخص من وضع قيمة تخزين مئوية إما 847و 847- وكلاهما خارج نطاق المجال المرغوب. 
تستطیع إضافة عبارة الشرط || لمحدد ٣0ءومءءهالوصول‏ هءءلرفض البيانات المرفوضة»ءولكن الخاصيات لا توفر طريقة للعودة بكود الحالات الفاشلة.والطريقة 
الوحيدة لإعلام الكود المستدعي عن المشكلة هي توليد استثناء. 
Set (ByVal value As Integer)‏ 
TE walue € O) OF wale > 1O00) Then‏ 
Throw New ArgumentOutOfRangeException ("value",value, "The allowed range is‏ 
EO O EO 1O0.)‏ 
Else‏ 
StoredPercent = value‏ 
ERA IEE‏ 
End Set‏ 
والان»محاولة وضع قيمة للخاصية lnEffectPercentخارج‏ المجال 0-100)-0سيولد خطاءخطا يمكن أن یتم التقاطه بواسطة معالج الخطİ On Error‏ أو 
ry...catch.تقبل‏ العبارة wەr‏ م ۲كائن ەناممxc٤.‏ مارك أو كائن مشتق منه كمعامل نسبي لهاء وترسل كائن الاستثناء ذلك إلى ركام الاستدعاء في البحث عن 
معالج خطا ما. 
ما يشابه عبارة ٣۲٥۷‏ 1هي الطريقة ماه ۴۲۲.۸8.وهي تتيح لك توليد أخطاء باستخدام عدد معتمد على نظام الأخطاء والمعروفة أكثر بالنسبة للفيجوال بيسك6والبيئات 
الأقدم.إني أوصي باستخدام العبارة Wه۲٣ءحتى‏ ولو كنت توظف معالجة الأخطاء الغير تركيبية في مكان أخر في كودك. 


إنك حر في مزج طرق معالجة الأخطاء التركيبية والغير تركيبية بصورة عامة في تطبيقك»ولكن يمكن أن يستخدم إجراء أو طريقة وحيدة طريقة واحدة فقط. ويمكن 
أن لاتستخدم کل من E٣0۲‏ 0 و اا2 at1...۴...رآ‏ في نفس الروتین. یمکن لروتین یستخدم ۴٣٥۲‏ 0۸ أن يستدعي روتين خر تدم Try...Catch...Finally‏ 
بدون أية مشكلة. 

الآن يمكن أنك تفكر بنفسك" أحيانا أستطيع بكل سهولة أن أحدد الوقت الذي أريد استخدام معالجة الأخطاء الغير تركيبيةءوأحدد الأوقات الأخرى عندما أرغب باختيار 
مقاربة تركيبية على الأغلب."وكل هذا يبدو معقولا جداءولكن دعني أحذرك سلفا أنه توجد معالجة أخطاء متزمتة بحيث تجعلك سخرية لعقود إذا ما استخدمت عبارة 
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Error‏ 0 في كودك.لمٿل هو لاء المبرمجين ما هو أساسي عندهم هو التوجه الكائني المجرد»وأي كود يستخدم طرق غير كائنية لتحقيق ما يمكن تحقيقه رة من خلال 
محاكاة البرمجة الكائنية التوجه یجب أن یدمر. 
رفض عبارة Er ٣0۲‏ 0 لمتل هذا هو من الغباء بمكان.فكما تذكر من فصول سابقةءأن كل شيء في تطبيق الدوت نت موجه بالكائنات»وبما أن جميع الكود يظهر في 
سياق کائن ما .فاذا کنت تستخدم معالجة الأخطاء الغير تركيبيةءماتزال تستطیع الحصول ى کائن استثناء مناسب من خلال الطريقة ) Er. GetException(‏ ذلك 
ليست الكائنات هي القضية الحقيقية. 
تقرير متى يتم استخدام معالجة الأخطاء التركيبية أو الغير تركيبية لا تختلف عن ما تم تقريره للاستخدام في السي شارب 0# أو الفيجوال بيسك لكتابة تطبيقاتك.من 
أجل معظم التطبيقات»المفاضلة في غير محلها,فيمكن أن يكون لدى لغة بعض الميزات الخاصةع| ماموم بها والتي يمكن أن توجهك في اتجاه ما(مثل المعاملات 
النسبية الاختيارية للطرق في الفيجوال بيسك)ولكن 99.9 من الميزات المتبقية تكون متشابهة إلى حد ما. 
ونفس الشيء صحيح بالنسبة لطرق معالجة الخطأ.وفي بعض الأحيان هناك ميزة سهلة وأفضل من أخرى.على سبيل المتال»خذ الكود التالي والذي يستدعي ثلاث 
طرق»ولا واحدة منها تتضمن معالج خطأً خاص بها. 
OM EEO Kesue Nexë‏ 
RefreshPart1l ()‏ 
RefreshPart2 ()‏ 
RefreshPart3 ()‏ 
من الواضح»أني ل أبالي فیما إذا کان الخطاً يحدث في واحد من الإجراءات أو لا إِذا ما سبب خظا ما خروج مبکر من ښ1ٍRefreshP›الروتین‏ التالي ¢ 
RefreshPar2›سيبقى‏ قابل للاستدعاء.وھکذا. غالبا ما احتاج لکود تفحص الخطاً أكثر إتقانا من هذا.ولكن في کود قلیل التأئير »فان هذا سيکون کافيا .لإتمام نفس الشيء 
باستخدام معالجة الخطأ التركيبية سيكون هناك تضمين أكثر بقليل. 
HEV‏ 
RefreshPart1l ()‏ 
GaE eh‏ 
aE We‏ 
EY‏ 
RefreshPart2 ()‏ 
CEE‏ 
و e‏ 
EEV‏ 
RefreshPart3 ()‏ 
CAE‏ 
ERE TEY‏ 
ذاك الكثير من الكود الزائد بالنسبة لنفس التخصص الوظيفي.إذا كنت من الكار هين لعبار ۴۲٣٥۲‏ "0 .بكل الوسائل استخدم المقطع الثاني من الكود.ولكن إذا كنت 
مبرمج أكثر عقلانية »استخدم كل طريقة إذا ما كانت مناسبة في تصميم كوك. 


إن الفئة هناممء×٤."هاءروهي‏ الفئة القاعدية بالنسبة لجميع الاستثناءات التركيبيةوہم‌نام ٠×‏ ۵١٥۲ع‏ ٣ء‏ .عندما يحدث خطاً ما.تستطيع تفحص أعضاءها 
لتحديد طبيعة الخطاً بدقة.وإنك تستخدم أيضا هذه الفئة (أو واحدة من فئاتها المشتقة)لبناء استثناء خاص بك في انتظار ٥۸‏ اماناج | استخدام عبارة۷W٥‏ ۲۲ . 
يجدول الجدول التالي Îعضlء«‏ اÛکlئExceptionj. system‏ 


Data‏ خاصية توفر إمكانية الوصول لتجميع أزواج قيم المفاتيح»وكل منها يوفر معلومات إضافية خاصة بالاستثناء. 


InnerException‏ خاصية»إذا کان استتناء ما هو تأثير جانبي عن Ea‏ أخرءفان الخطاً الأصلي يظهر هنا 
خاصية تعرف اسم الاستتناء أو الكائن الذي سبب ذلك الخطا. 
خاصية تعرف اسم الطريقة التي أطلقت الخطا. 
الفئات المشتقة من هنام هء×۴.”هاءر8 يمكن أن تتضمن خاصيات إضافية توفر تفاصيل إضافية لنوع خطأ نوعي. 


يوفر الكائن ٣‏ إمكانية الوصول لأغلب الأخطاء الحديثة من خلال أعضاءه المتنوعة.أي وقت يحدث خطاً ماءتوثق الفيجوال بيسك تفاصيل الخطأ في أعضاء هذا 
الكائن. على الأغلب يتم الوصول له(لكائن الخطاً) ضمن معالج خطأ غير تركيبي للإشارة أو عرض تفاصيل الخطأ.يبين الجدول التالي أعضاء كائن الخطاً ۴۲۲. 


عنوان رقم السطر الأقرب لمكان حدوث الخطأً.في تطبيقات الفيجوال بيسك الحديثةءعناوين الأسطر المرقمة على الأغلب لاتستخدم. 
لذلك بشكل عام هذا الحقل هو0. 


Erl property 


الموضع الذي ضمنه ملف المساعدة على الشبكة فيما يتعلق بالخطا.إذا كانت هذه الخاصية وخاصية ٠إماهإتم‏ وضعهاءفان المستخدم 
يستطيع الوصول لملف معلومات المساعدة ذات الصلة بالموضوع على الشبكة 


HelpContext property 


Number property‏ الكود العددي للخطا الفعال. 
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Source property‏ اسم التطبيق »أو الفئةءأو الكائن الذي يولد الخطاً الفعال. 


الفيجوال بيسك6(و الأقدم)تتضمن أداة مساعدة والتي ستخرج بسرعة معلومات تصحيح من البرنامج»و عرض متل هذه المخرجات في "النافذة المباشرة مأجاdمص"|‏ 
Wİ "0W‏ " لبيئة تطوير الفيجوال بيسك. 
Debug. Print ("Reached point G in code")‏ 

إصدار الدوت نت للفيجوال بيسك يحسن كائن التصحيح وںطه مع ميزات أكثر »وتغير بسيط في البناء.تم تبديل الطريقة ۴ب ٣٠‏ أاعا ۷ الطريقة ۷٣٤٥‏ تخرج 
نص بدون لاحقة عودة المشيرة ٢۲اه‏ موه ا٣ء‏ في النهاية. 

Debug.WriteLine ("Reached point G in code") 
كل شيء تخرجه باستخدام الطريقة ماعن (أو ما يشابهها) يذهب إلى سلسلة "المصغيات ء٣٥ هوا "الملحقة (المرفقة) بكائن التصحيحوں طم .تستطيع إضافة‎ 
منصتاتك الخاصة»ء»متضمنة المخرجات لملف العمل.ولكن كائن التصحيح Debugيڌمp استخدامه فعلیا فقط عند تصحیيح برنامجك. حالما تترجم الإصدار الأخير‎ 
لبرنامجك»فلا تعمل أي من الميزات المتعلقة بالتصحيح بعد ذلك»بشكل تصميمي.‎ 
).فهو مشابه للکائن‎ ۸58P .N.٤ ۲ إذا كنت ترغب بتسجيل حالة البيانات من التطبيقات المحررةءخذ استخدام الكائن وه.i0۸اaءiاممMy.A (أووما.رM في برامج‎ 
ءاوه .بشكل افتراضي»جميع المخرجات تذهب لمخرجات تصحيح قياسية(تماما‎ ٣١١ يرسل الكائن مخرجاته لأي عدد من المنصتات المسجلةء ه١ ءا‎ »0هطuو‎ 
. application's assع مثل كائن التصحيحوںطه5 )وإلى ملف التسجيل «ااوه!| الذي يتم إنشاءه بشكل خاص لمجمع تطبيقك راص‎ 


تتضمن لغة الفيجوال بيسك القليل من العبارات الخاصة بالأخطاء والميزات الأخرى والتي يمكن أن تجد أنها مفيدة: 


ترجع هذه الطريقة برسالة الخطاً المرافقة لكود خطا النظام العدديٰ ٥٣٣٥٣‏ ٣ءء‏ ع اامہںم »على سبیل المثالء (10) و۸ 1اا ٥5‏ ٣۲٣٥ءا‏ تعود ب'يتم إصلاح 
هذه المصفوفة أو إغلاقها بشكل موقتل kع0!‏ ا٣ array ¡s fixed or tempo‏ ءآ "وهي مفيدة فقط مع أكواد الأخطاء الغير تركيبية الأقدم. 


عندما تزود معامل نسبي کائني لهذه الخاصية»ءفاإنها تعود بصواب إذا کان الكائن هو كlئSystem.Exceptionj‏ (أو مشتق منه) 


سيكون كود مشروع هذا الفصل مختصر .وسیظهر كود معالجة الخطاً وہاا ۴٣٥۳-٣۵‏ على مدى كامل التطبيق»ءولكن سنضيفه قليلا قليلا كلما تقدمنا في صناعة 
المشروع.أما الآنءدعنا نركز على إجراءات أو روتينات معالجة الخطاً المركزي والذي سيشغل بعض الفعل الأساسي عندما يحدث خطأ ما في أي مكان في البرنامج. 
أما بالنسبة لتعابير لامداء سنؤجل متل هذا الكود حتى فصل متأخر. 
بقدر أهمية ودقة الحاجة إلى معالجة الخطأءفإن تطبيق العمل النموذجي لن يصادف تنوع كبير في أنواع الخطأً.وتطبيقات مثل مشروع المكتبة غير محصنة بشكل 
رئيسي بالنسبة لثلاثة أنواع من الأخطاء©1)أخطاء إدخال البيانات»(2)الأخطاء التي تحدث عند قراءة البيانات من أو كتابة البيانات إلى جدول قاعدة بيانات»(3) 
الأخطاء المرتبطة بالطباعة.من المؤكد أنه توجد أخطاء عددية لتجاوز الحد أو أخطاء أخرى مرتبطة بالبيانات التي قيد الاستخدام»ولكنها على الأغلب تتفاعل مع 
المصادر الخارجيةءمثل قاعدة البيانات والتي هي محور اهتمامنا. 
بسبب محدودية أنواع الأخطاء التي تحدث في التطبيقءفمن الممكن كتابة روتين شامل يخبر المستخدم عن الخطأً بأسلوب ثابت(مستقر).کلما حدث خطأ وقت التنفيذء 
سنستد عي هذا الروتين المركزيءلنتيح للمستخدم معرفة ما يجري.يمكن لمقطع الكود عندما يحدث الخطأ أن يقرر فيما إذا سيجري آي فعل مكافئ خاص» او أن يستمر 
وكأن ليس هناك خطأاً قد حدث. 
في المشرو ع»افتح ملف الفئة طا ./و٥‏ ع6 »ءوأضف الكود التالي كطريقة جديدة للوحدة البرمجية اوهمG.‏ 
Public Sub GeneralError (ByVal routineName As String, ByVal theError As System. Exception)‏ 
Report an error to the user.‏ س 
On EFFOr Resume Next‏ 
vbOrLÊ & vbCrLE & theError.Message,‏ & ":'" & utineNameدr‏ »& "' حدث الخطأً التالي عند الموقع") ×980ئM‏ 


MsgBoxStyle.OkOnly Or MsgBoxStyle.Exclamation, ProgramTitle) 
My.Application.Log.WriteException (theError) 


End Sub 
م"ه6.‎ 2|۴٣0 إليك كيف يعمل. عند تصادف خطا في روتين ماءيستدعي معالج الخطأ النافذ المفعول الطريقة المركزية‎ 


PUbDl1ICG Sub SomeRout1ne () 
On EEEOSE GOLO HEESEHANALEE 
aS UOoOES Of COde Here. 
Return 
ErrorHandler: 
GeneralError ("SomeRoutine", Err.GetException () ) 
Resume Next 
ل‎ 9 
تستطيع استخدامه مع الأخطاء التركيبية كما يلي:‎ 
TEY 
ڪڪ ل‎ Troubling code here. 
Catch ex As System.Exception 
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GeneralError ("SomeRoutine", ex)‏ 
O Me‏ 
الهدف من الطريقة العامة ۲٣٥۲‏ اهمه بسيط:ينقل للمستخدم أن هناك خطأ قد حدث»ءومن ثم ينتقل للأمام.تستطيع تحسين الروتين ببعض الميزات الإضافية.تسجيل 
الخطاً إلى ملف خارجي(أو إلى أي منصت مسجل ١٠٥٠ءا‏ وه! فعال)يمكن أن يساعدك فيما بعد إذا ما احتجت إلى تفحص الأخطاء الناتجة عن التطبيق.كما في 
السطر التالي المضاف إلى الطریقة 2|۴٣۲‏ مممG.‏ 
My.Application.Log.WriteException (theError)‏ 


بالطبع»ءإذا ما حدث خطأ بينما تتم الكتابة إلى السجلءفذلك سيكون مشكلة كبيرةءلذلك قمنا بإضافة سطر أخر لبداية الطریقة ۴0۲ ۴2٣ه6.‏ 


On EEFEOE Resume Next 


كما ذكرت سابقاًءإنها فكرة جيدة أن تضمن معالج خطأ شامل في كودكءفي حالة إذا ما تغلب خطأ ما على دفاعاتك.لتضمين هذا الكود»أعرض جميع الملفات في 
مستكشف الحلول باستخدام زر "إظهار جميع الملفاتءع|۴ ١ا۸‏ سطكS‏ "٠افتح‏ الملفط۷.ئام م 0”Eنcat//ممA‏ «وأضف الكود التالي إلى الفنة ہمناicaامMyAp.‏ 
Private SMO MyAgPpINEaet om UnnandledJExe esl1 On (BvVal Sender AS OB ect, EVIN 6 AS‏ 
Microsoft.VisualBasic.ApplicationServices.UnhandledExceptionEventArgs) Handles Me.UnhandledException‏ 
Record the error, and keep running.‏ حص ا 
e.ExitApplication = False‏ 
GeneralError ("Unhandled Exception", e.Exception)‏ 
End Sub‏ 


بما أن لدينا سابقا الروتین "٠2۴۲۲٥١۲‏ 6لتسجيل أخطاءناءمن الممكن أن نستفيد منها هنا. 
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ألقضل آلطائر ادو قرت نت Mhm76‏ 


الا دو دوت نٽ ADO.NET‏ 
إذا كنت مطور ويندوز جديد.فإنك لم تتعرف بعد على الاختصار ات التالية.بعض الأحيان متعارضة»ءوأحيان أخرى أدوات تفاعل قاعدة بيانات متممة: 
08C.‏ فتح قاعدة البيانات في Jlفالة‏ المتأ¬صlة.Connectivity ODBC—Open Database‏ 
.5 طريقة الوصول التسلسلية llلمفر‏ wة.Meth0d ISAM—Indexed Sequential Access‏ 
Data Access Objects.ٽlنlڊl Jصولl تliئlS DAO.‏ 
.liilSRDOت‏ lııllنlت‏ llبعيدةObjects Remote Data‏ 
01۶٤ .‏ ربط وتضمين الكائنات لقاعدة llبlıنlت Object Linking and Embedding for Databases‏ 
Jai ADO.‏ س lÛJئنlت‏ |lilJlت. ActiveX Data Objects‏ 
عندما تنظر إلى هذه القائمةمن المحتمل أن تفكر (هذا عظيم»يوجد الكثير من الخيار ات للاختيار منها.)فستكون أحمق بهذا التفكير.فهذه القائمة ليست عظيمةءإنها 
مخيفة.تصورء ولدقيقة فقطءفنحن لم نتحدث حول واجهات كه ه۲۴٠٣‏ قاعدة البيانات.ولكن من ناحية أخرى»هي قضايا أكثر عملية. 
عندما قدمت ميكر وسوفت تقنية كائن قاعدة البيانات الجديدة ضمن المزيج»عملت على تبعها سريعاً بطفرة إعادة برمجة لجلب "الميراث "الأقدم لتطبيقات للفيجوال بيسك 
والتي تعود لتقنية قاعدة البيانات الأحدث.وهذا لم یکن ممکناً دائماًء إلى هناءمن الواضح آن آدو دوت نت .مكتية قاعدة بيانات ميكروسوفت للدوت نت.مختلف. 
إذا كنت على إطلاع على تقنية 400 تجهز لتنساها.فإن آدو دوت نت ليس بالخليفة الطبيعي لدو ۸20 .إنه بالكامل تقنية جديدة ليس لها علاقة بآدو»وعلى الرغم من ذلك 
فهي تتشارك بعض التقذية مع آدو والآدوات الأخرى الأقدم»وتفعل آدو دوت نت هذا لتلعب بعقلك. 


إن آدو دوت نت مجموعة من الفتات» المضمنة مع إطار عمل الدوت نت.و تمثل الطريقة الرئيسية التي بواسطتها تتفاعل تطبيقات الدوت نت مع قواعد البيانات العلائقية 
وأنظمة إدارة وفتح البيانات الخاصة الأخرى ولكنها ليست للتفاعل فقطءفي الحقيقةء إن آدو دوت نت قاعدة بيانات علائقية جزئية في الذاكرة قائمة بذاتها.تستطبع إنشاء 
الجداول والعلاقات(الروابط) من خلال كائنات آدو دوت نت»إضافة »وإزالة أي سجلات.استعلامات الجداول بالاعتماد على معيار "الاختيار 5٣1.٤٤7‏ " وعمل مهمات 
أخرى بسيطة والتي هي نموذجية بالنسبة لأنظمة قواعد البيانات العلائقية القائمة بذاتها. 
جميع الفئات المضمنة مع آدو دوت نت تظهر في فضاء الأسماء aة50.٠ءاءر؟‏ .بعض فضاءات الأسماء التابعة(التانوية ٥ة٠iل١۲هطناء‏ )توفر فئات مشتقة مجهزة 
باتجاه منصات قواعد بيانات خاصة(نوعية(« على سبيل المثال«يستهدف èخضlء‏ |lawÎJء SQL Server databasesJgكw تlil sel System.Data.SqIClie nt‏ « 
System.Data. racleClient‏ يركز على آنظمة إدارة قواعد بیانات أوراکلء"e†ءرء؟N‏ ۸08 0۲۵٤1۵‏ .ویمکن لموفرات قواعد بیانات أخری تطویر تنفیذات 
انسيابية لفئات آدو نت المتنوعة للاستخدام مع أنظمتها الخاصة»وتز ود بها كفضاءات أسماء منفصلة. 
تنفذ ٤۲‏ A00.Nتجربة‏ بيانات غير متصلةعء۸ء disconnected data expe‏ .في برمجة قواعد البيانات التقليدية وخاصة تطبيقات سطح المكتب مها )كمك 
icationsاممه.الاتصال‏ بين تطبيق ما وقاعدة بياناته تم إصلاحه ولاأجل طويل.عندما بيدا التطبيقءيبدأً الاتصال.وعندما يخرج التطبيق بعد عدة ساعات»فإن الاتصال سيتم 
إنهاءه أخيرآً.ولكن في عالم مواقع الانترنت الضخمة والقابلة للتوسعء المحافظة على قاعدة البيانات في وضع الاتصال لساعات طويلة دون انقطاع تكون في بعض الأحيان 
تبذیر (إسراف)وغالباً کون مستحیل. 
تشجعك ادو دوت نت على فتح اتصالات طويلة بشكل كافي للحصول على البيانات التي تفي كءااأ؟۴اناfباحتياجاتك‏ المياشرة.حالما تكون البيانات لديك.فإنك تسقط الاتصال 
حتى تحتاج في الوقت أخر استخراج, أو إدخال» أو تحديث محتوى قاعدة البيانات.إذا أصدرت عيارة سكول التالية: 

SELECT * FROM Customer WHERE BalanceDue > 0‏ 
لديك خيار(ا)اختبار جمبع السجلات حالاً وسرعة وبطريقة بسيطةأو(2)تحميل البيانات إلى جدول في الذاكرة مثل الكائنءوإغلاق الاتصالءوالعمل مع السجلات المحملة 
وكأنها السجلات الأصلية.إذا استخدمت الطريقة الأولى.تستطيع تمضية وقت جيد في التنقل بين السجلات.وتأخذ عدة دقائق في معالجة كل منها.ولكن أدو دوت نت يمتعض 
(يرفض٣‏ 0٥م‏ ١١۷٠٥ء۴‏ )هذا النوع من التصرف الأناني.الهدف هو الدخول وأخذ البيانات بالسرعة الممكنة.بسيب الطبيعة الغير متصلة disconnected "ature‏ 
للدوت نت. فيعض التقنيات الشائعة في تطبيقات قواعد البيانات تحتاج التغير.على سبيل المثال البحث طويل الأمد في سجلات قاعدة البيانات خلال تعديل المستخدم 
("التز امن السيئرء١٠٣إncuهc‏ ticءmiاsمم‏ ")صعب التحقيق في البيئة الغير متصلة للدوت نت.سيكون عليك استخدام طرق أخرىء»مثل التعاملات(المداولات) أو 
ميزات الاإجراء المخزن الصغيرة.لانجاز نفس الهدف. 


يقسم الدوت نت عالمه إلى نصفي كرة:الموفر ات كء۲ع ۲٠١4‏ ومجموعة البيانات٤ءء‏ 400 .توفر الموفرات إمكانية الوصول إلى محتوى ماءمثل قاعدة بيانات أوراكل . 
ر السارات مطل على كك وكاب الك الأحلى الى ف الخضةل عة هن الفخرن الطول الداع السانات اها ن اللخار كط تة اة ا 
سيتم إعادته إلى قاعحة البيانات للتخزين الطويل الأمد إذاً تمنحك الموفر ات إمكانية الوصول إلى البيانات المخزنة.بعض البيانات يمكن أن يتم نقلها ومعالجتها من خلال 
تطبيق ما ومجموعة بياناته على قاعدة تخزين قصيرة الأجل. 


أنظمة قواعد البيانات كء"٣#اءرء‏ #ءةطه†aه‏ الضخمةءمثل مخدم سكول ١۲۷#ه؟‏ ا5 وأوراكلءاءة0۲ . هي مخدمات قائمة بذاتها تتفاعل مع أدوات وتطبيقات العميل 
بشكل غير مياشر فقط .هذه الأنظمة تقبل بشكل عام اتصال شيكة من العملاء من خلال منفذ بروتوکول التحکم بالارسال/بروتوکول الانترنت ٤0۲م‏ ۲۳۴/1۴ أو اتصال 
مشابه.حالما يتم التصديق ك هء ١٠اه‏ يستطيع الزبون عمل جميع متطلباته من خلال هذا الاتصال قبل قطع الاتصال عن النظام.في عام 1990نفذت ميكر وسوفت 
(فتح قاعدة البيانات في الحالة المتصلة٣‏ 028 )(بالاعتماد على معايير موجودة)كنظام عام من خلاله يمكن للعميل أن يتصل بمخدمات قاعدة البيانات»بالاضافة لمصادر 
البيانات الأخرى الأبسط.لن يقلق العملاء بعد هذا حول جميع بروتوكولات شيكة العمل الضرورية لمحاكاة قاعدة البيانات. كل ذلك الكود تم تضمينه في مشفل 008€. 
أطلقت ميكر وسوفت فيما بعد نظام اتصال بيانات مشابه يدعى08 01٤‏ (ربط وتضمين الكائنات لقاعدة البيانات) بالاعتماد على تقنية ×۷ا٤۸.حالما‏ ظهرت مشغلات 
D8‏ 0۴ للأنظمة المشتركة»وعلى الرغم من أنك ماتزال تستطبع الدخول إلى مصادر €٤008من‏ خلال مشفل 28٤‏ 0الشامل المبني ضمن 58 ٤ا0.‏ 
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في الدوت نت»كل من ٤008و‏ 08 01۴ تم استبدالهما بكود المكتبات5٠|۲‏ ه۲ طا »والموفرات كء۲٥‏ ۷4٠۲م‏ التي توفر جميع الاتصالات بين قاعدة البيانات وتطبيقك.إن 
الموفرات هي الجزء المكمل لآدو دوت نت ۸00.۴۲ .وعليك استخدامها للحصول على قواعد بياناتك.لحسن الحظتتواجد الموفرات من أجل أنظمة قواعد البيانات 
الرئيسية»ویتواجد موفر 508 ٤ا0‏ من أجل الاأنظمة التي هي بدون موفر بنفسها. 


هذه الكائن يوجه الاتصال بين برنامجك ومصدر البيانات.إنه بتضمن خاصيات وطرق تتبح لك الإشارة إلى موقع أو وسيطات الاتصال لمصدر البيانات.العديد من أوامر 
العمليات(الاجراءات) يتم إدارتها عند مستوى هذه الكائن. 


يأخذ هذا الكائن عبارة سكول ا @5التي توفرهاء ويحضرها ليتم نقلها من خلال كائن الاتصال.تستطيع تضمين وسيطات في أمرك لتخزين إجراء ودعم عيارة معقدة. 


يوفر كائن قارئ البيانات طريقة بسيطة وفعالة لاستخراج تتائج من استعلام بيانات .تستخدمه كائنات أخرى في الدوت نت لاستقبال وإعادة توجيه البيانات للاستخدام ضمن 
برنامجك.ولكن يستطيع كودك استخدامه مباشرة لمعالجة نتائج عبارة "اختر 5۴1٤١‏ "أو إجراء استخراجي لبيانات أخرى. 


هذا الكائن هو مايجعل الاتصال بين مجموعة البيانات وباقي الموفرات ممكنة.واحد من أعماله الرئيسية هو تعديل عبار ات معالجة البیانات( عيارات ٤5۴1۴و‏ 
I[NSERT.و‏ PDATEل‏ .و ELE‏ )المولدة بواسطة مجموعة البيانات في تنسيق يمكن أن يتم استخدامه بواسطة مصدر الييانات المناسب(ذو الصلة). 
استخدام هذا الكائنات مقعد قليلاًء ولكنها ليست صعبة الفهم. 
1.أسس اتصال لمصدر بياناتك باستخدام كائن الاتصال. 
2.ضمن عبارة سكول في كائن الاأمر. 

3.نفذ كائن الأمر في سياق الاتصال المؤسس له. 


4.إذا كان يجب استعادة أي بيانات» استخدم إما قارئ البيانات 2۸٠20۲‏ 03لعمل مسح خلال السجلات» أو دمج(ضم)لكل من "محول بيانات 6۲ا م2 D22۸‏ " 
و"مجموعة بیانات 0256٤‏ (أو جدول بيانات ا02۵ )" لاستخراج أو تخزين النتائج. 

5.أغلق كل الكائنات التي قمت بفتحها لمعالجة البيانات. 

له ال كن أن إطار ع الع ت ت ضفن ف ا اا هة هي اة اا ت ا ا ن ر فک ل ف 
والذي يتم عرضه مj‏ خlڵJ‏ فضlءs .System.Data.SqIClient sll‏ 


الميزة امتياز أدنى مو#اأ۷اام-٠٠!‏ للمستخدم للوصول لملف قاعدة بيانات سكول سرفر السربع دون الحاجة لمدير 0اهءاءİمİ‏ "هه من أجل تأسيس إعدادات أمان سكول 
سرفر لذلك المستخدم.وهذه الميزة مفيدة في البيئات حيث البرمجيات المرتبطة تم تنصببها من خلال طريقة التوزيع "بنقرة واحدة مء" ۸0ء//C‏ "(سيتم مناقشتها في الفصل 
5 إن شاء الله)دون تضمين للمدير١0ة٠ءi١‏ "۵ه .ويتطلب أيضاً تركيب خاص لتنصيب لسكول سرفر السربع قبل الاستخدام.ولمزيد من المعلومات حول هذه الميزة 
راجع موضوع"العمل مع حالات المستخدم"في قسم "الدوت نتءع۸cھاءہ! Working with User‏ " في مستندات شبکة مطوري ميکر وسوفتN‏ ۱520 .والموفرة مع 
تنصيب الفيجوال أستوديو إذا كنت قد نصيت هذه المستندات «S0‏ . 


إذا كنت في طريقك لعمل أكثر من مسح ١هءءللبيانات‏ الراجعة من استعلام قارئ البيانات ٠20٠۲‏ 12۸Rه0‏ .من المحتمل أنك سوف تستخدم مجموعة البيانات أهء اجك 
لتخزين أو إدارة أو بشكل اختياري تحديث بياناتك.توفر كل مجموعة بیانات عرض غير متصل(بدون اتصال)شامل ٣68٩ ۷۴W‏ 0ءءiك‏ مهو للبيانات.»سواء 
كانت بيانات من موفر أو بيانات عملت على بناءها من خلال الكود .على الرغم من أن كل موفر يتم ربطه بمنصة قاعدة بيانات معينة(مثل أوراكل)أو اتصال قياسي(مثل 
8 ع 0).الكائنات في مملكة مجموعة البيانات هي شاملة.ويمكن التفاعل معها بأي موفرات خاصة بمنصة. 

تلاث کائنات تركب عالم مجموعات البیانات‌ءاهء daa‏ : 


يتصرف كل كائن مجموعة بيانات كقاعدة بيانات صغفيرة.تستطبع إضافة العديد من الجداول لمجموعة البيانات كما ترغب»وتؤسس علاقات مفاتيجح ثانوية fo ۲re19-)€¥‏ 
relationships‏ بين حقول كل|اعاأهذه الجداولءهاطه) .ذاتيات كاج١۲عامiكل‏ مجموعة بيانات هي غامضة نيaكj‏ ıwڊرl unfathomable mystery‏ .Jyكj‏ 
تستطبع تصدير كامل مجموعة بيانات 0561ل ا ×. وتعيد تحميله مرةً أخرى فيما بعد لما كان عليه إذا كان يجب عليك ذلك. 


كل جدول ءاطهافي مجموعة بياناتك a56‏ 2يستخدم كائن جدول بيانات ٥اطة٠‏ واه منفصلءوقابلية الوصول له تتم من خلال تجميعg‏ جدlوJ Tables collecti0n‏ 
مجموعة البيانات 1856ه0 .إن جداول البيانات مفيدة أيضاً ككائنات قائمة بذاتها.إذا خططت لاضافة جدول مفرد لمجموعة بياناتكه185ة0 .من المحتمل أنك تفضل 
استخدام فقط كائن جدول بيانات ءاطه۲هة0لوحده بدون مجموعة بیانات6 ٥a5‏ .ضمن کل کائن جدول بيانات اط2 0a4‏ .کائنات DataColumn ٽlilaڊ oe‏ 
وصف بيانات 0W‏ 028۴8 منفصلة تؤسس تعريفات حقل ۵| اأوقيم ١6ا۷2‏ بيانات حقيقية»على الترتيب. 


استخدم كائنات علاقة البيانات ١‏ هناهام 28اه .المخزنة ضمن تجميع علاقات مجموعة الييانات Data Set's Relations coااء ا٥ ٣N‏ .لتأسیس علاقات على مستوی 
الحقل relationships‏ اleve-field‏ وقيود constraintsبين‏ الأعمدة في کائنات جدول البیانات ا5242 . 

على الرغم من أن مجموعات البيانات كأهء aاةل‏ على الأغلب يتم استخدامها مع الموفرات#۲5لا۷١١م‏ .تستطبع استخدامها بشكل منفصل لبناء تجمبع خاص بك في 
الذاكرة للجداول والعلاقات. وهذا مشابه ل"مجموعات سجلات العميلءاهء ١۲١ء٠۲‏ مه اء-اممااء "والتي تستطبع بناءها بكائنات آدو السابقة لآدو دوت نت 


الفصل العاشر:آدو دوت نت 


Mhm 76 


م١١6۴ التي تجعل مجموعات البيانات كأهء هاه أكثر قوة من مجموعات السجلات الاأقدم‎ ۸00.٤١ .على الرغم من الميزات المضمنة في‎ ماe-..‎ E۲ A0 
.record sets 


سجلأة ”0۲ كإoعre‏ .تستخدم تقنية لينكو K۵‏ الجديدة ميزة مشابهة للمساعدة في تأسيس علاقات بين لينكو وجداول قاعدة البياناتءهاطه مasطه†da‏ . 


عندما يتم استخدام كل من الموفرات ومجموعات البيانات مع بعضها فإنها تمنح واجهة نهاية(طرف) - إلى- نهاية(طرف) لقيم البيانات المستقلة من حقول في جداول قاعدة 
البيانات إلى بنود في الذاكرة لسجل صف بيانات ٥W‏ ۸هه0 .ييين الشكل التالي تفاعل هذه الكائنات.عندما تتفاعل مع بيانات من قاعدة بيانات خارجيةء إنك دائماً تستخدم 
فثات الموفر 6۲ ١۷٠۲م‏ .ولكن يعود لك فيما إذا كنت تريد استخدام مجموعات البياناتءاهء هاه .يوجد محاسن وسيئات لكلا الطريقتين»بعض منها يظهر في الجدول 
التالي: 


عليك توفير جميع عبارات سكول.في تنسيق يتوقعه الموفر.وهذا صحبح لجميع 
oتطlılٽ .DELETE g UPDATE g INSERT g SELECT‏ 

البيانات المستخرجة من خلال ١٠لة٠۸اة‏ دهي للقراءة فقطعليك أن تصدر 
أوامر منفصلة لتحديث البيانات. 


تنقلات البيانات فعالة جدآءبما أنه ليس هناك حاجة لتكاليف نقل البيانات ضمن 
تجمبع الذاكرة يكون محدود لسجل مفرد مساوي لحقول البیانات» ز ائد بعض 
التكاليف الصغيرة. 

یمکن أن یتم فتح قارئ بيانات۲٥۵ 04۸٠۵‏ مفرد فقط في نفس الوقت(مالم 
يدعم الموفر 1۸88S‏ والذي سأناقشه فيما بعد) 

عمر الاتصال بقاعدة البيانات يتواجد طالما أن قارئ البيانات 04۸٥206۲‏ قيد 
الاستخدام. فإذا استفرقت خمس دقائق لمسح مجموعة بيانات ناتجة لاأنك تعمل 
الكتير من تحليل السجلات المسبقةءفإن الاتصال سيبقى فعال كامل الخمس 
دقائق. 

تحضر قار ئات البيانات ۲5٠4۵٠8۸اة0سجل‏ كل مرة.ويجب أن يتم معالجة 
السجلات في ترتيب الاستخراج. 

تمضي الكثير من الوقت في العمل مع النصوص(من أجل عبارات سكول) 
وحقول بيانات الصف. 

کل أمر con nand‏ واتصال connection‏ يعمل مع مصدر بیانات یدعم موفر 
مفرد. 


بسبب أنك أنت الذي تدير جميع عيارات سكول ا8۵ .ءفإن لديك (نسبياً 
yاativeاها)‏ مستوى عالي من السيطرة على عمليات تفاعل البيانات بالكامل. 


يعمل كل من مجموعة البيانات tet‏ ومحول البيانات ءام aل0at24مع‏ بعضهما لصنع 
العديد من عبارات سكول عوضا عنك. 

قراءة البيانات من قاعدة البيانات يمكن أن يتم تعديلها في الذاكرة »ويتم تحديثها كمجموعة 
مع استدعاء طريقة مفردة. 


AEN GS A SENS SET ES e 
لکل سجل منقول.‎ 

تجميع الذاكرة مطلوب لمجموعة ناتجة بالكاملء ز اند التكاليف بالنسية لكل جدول»حقلء 
ةوالتو ى الفموغ الات 

أ عد من فخموعات انات تن أن كرون 315 قي اف الوت 


اتصالات البيانات يتم حفظها فقط بطول كافي لنقل البيانات من أو إلى قاعدة البيانات فقط . 


تستطبع القفز فوق السجلات في مجموعة البيانات»وتمايز بينهم لتفي بمتطلباتك. 


جميع حقول البيانات يتم تنظيمها بشكل منطقي»تماماً مثل ما كانت في قاعدة البيانات الفعلية. 
يمكن أن تتصل جداول البيانات كماطة٣هاهدالمختلفة‏ ضمن مجموعة بيانات ة0 إلى 
مصادر بيانات متمايزة (مختلفةءهءءuهء‏ هاده ءاه ).وأيضاًءتستطبع صنع البيانات 
يدوياً لذلك کل صف بیانات 7۷٥14۴هديحتوي‏ بيانات من مصادر مختلفة. 

بسيب أن عرض البيانات هو مجرد ل#اءه٣1ءطه‏ .فإن لديك (نسبياً)مستوى محدود 
للسيطرة على عملية تفاعل البيانات بالكامل(على الرغم من أن الاستخدام المتقدم 
لمجموعات البيانات يعمل على منحك بعض التحكم الإضافي.) 
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الموفرات ومجم و عات البيانات أثناء اأعملئ Providers and data sets in action‏ 
بالنسبة لي فإن المدخلة الأخيرة في الجدول السابق هي الحاسمة.إن عمل الميرمج هو السيطرة على تجربة برمجيات المستخدمءوالأكثر تحكماً هو الأفضل.ولهذا السبب 
فإني أكره المعالجات السحرية كل١22۲س‏ و"مولدات الكودىهة۲٠٣‏ عو مهكه»ء " والتي تأخذ التحكم عوضاً عني. أو عوضاً عن المطور.على الرغم من أنني أصير على 
القالب المزود بواسطة الفيجوال أستوديو عند إنشاء مشروع جديد.مايزال وكما سترى .لمحات التحكم الشخصية على كودي في مشروع المكتية.مع اعتمادي الكبير على 
قارىئ البيانات ك۲5٥ك2٥‏ 1۸هد أكثر من مجموعات الييانات5اه25ه0 .عندما أعمل على تخزين البيانات على المدى الطويل.فإني عادة ألصق البيانات فقط في جدول 
بيانات eاط2‏ 24دون تضمين مجموعة بيانات5a†aS6‏ . 


لقد ذکرت فیما سبق شيء ما يدعىی 1۸۸8و ۸۸S‏ |اختصار "مجموعات ناتجة عن نشاط متەعددets‌S Active Result‏ eامtipاMu‏ "عادة.یسمح کائن اتصال 
Connection‏ مفر د لقارئ بیانات 214۸8٥206۲‏ مفرد لأن يكون قيد الاستخدام في وقت معين.وهذا التحديد هو ثتائي الاتجاهاة٠‏ اهلاط .إذا كنت تعمل مسح قارئ 
بیانات باستخدام عیارة "اختر ٥7‏ 1۴۔56 " فلا تستطیع إصدار عیارات إدراج |5٤۸٦‏ .تحدیث ۴0۸۲ل .أو حذف 0٤L۲‏ علی نفس الاتصال حتی تفلق قارئٰ 
البيانات ۸R ٠20٠۲‏ امد .مع تقديمS‏ ۱۸۸ »ءيمكن لاتصال وحيد الآن معاملة نشاطات انتقال بيانات في أي اتجاه.أضافت سكول سرفر دعم ۸1۸۸Sمع‏ الإصدر2005. 
وكذلك دعمت أراكل 1۸S‏ كالميزات منذ الإصدار الأول للدوت نت.تبدو اتصالات 1۸4۸S‏ كميزة تحتاج لتمكينها باستمرار.ولكنها تعمل على إضافة تكاليف إضافية 
لتطبيقك تبطئ تطبيقك.وأیضاً لا تمتزج دائماً مع التطبیقات ذات مسار ات التنفیذ |لمتعددnsö multithreaded applicatio‏ . 


إن للفيجوال أستوديو العديد من الأدوات الجاهزة والتي تجعل العمل مع البيانات بسيط كبساطة السحب والإسقاط حسناءليس بهذة السرعة.ولكن بالإجابة على القليل من 
الأسئلة وسحب وإسقاط بند واحد.تستطبع بناء تطبيق كامل يتيبح لك تحديث البيانات في قاعدة بياناتك.لنجرب ذلك معاً. 


ابدأ مشروع نماذج ويندوز جديد في الفيجوال أستوديو» أختر بيانات هأة0 > > أمر قائمة "أظهر مصادر البيانات esءu۲هS‏ ة0 SW‏ " مما يحضر لوحة مصادر 
البيانات كما هو مبين في الشكل التالي. 
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إن المشروع الجديد لا يتضمن أي مصدر بيانات بشكل افتر اضي.لذلك تحتاج لإضافة مصدر بيانات.أنقر على الوصلة"أضف مصدر بيانات جديد Add New D318‏ 
Source‏ " في لوحة "مصادر البياناتءەءu۲ه؟S‏ اه0 ".يقودك"المعالج السحري لتركيب مصدر بيانات" خلال عمليات إنشاء مصدر بيانات: 

1.تسألك الخطوة الأولى"من أين سيحصل التطبيق على البيانات؟اختر "قاعدة البياناتهءةطهاة " وانقر الزر "التالي × "(كما هو مبين في الشكل التالي 
(التخطيط الثاني)). 


Data Sources 


Data Source Configuration Wizard 


۴ Choose a Dala Source Type Data Source Configuration Wizard 


Where will lhe application get data from? LL Choose four Data Connecion 


lِ £ 


[Dalaba3| Service Object hich data connection should your application use to connect to the database? 


mhmhsqlexpress. Library. dbo New Connection... 


Lets youi connect lo a dalabaze and choose lhe database objects lor your appa 
dalasel. 


Connection sting 


4 Previous 1 EE 


2.تسأل الخطوة التالية."أي اتصال بيانات يجب أن يستخدمه تطبيقك للاتصال بقاعدة البيانات؟"سيكون علينا إنشاء اتصال جديد لقاعدة بيانات المكنبة والتي عملنا على 
تصميمها في الفصل الرابع.انقر زر "اتصال جديد١‏ هاا ممممC New‏ "(الميين في الشكل السابق (التخطيط التالت)) 

3.یظهر حوار اختیار مصدر البیانات.اختر میکر وسوفت سکول سرفر 56۷6۲ Micros) 5Q1‏ من قائمة"مصدر البیانات ۲٥٥‏ uهء‏ ھھ 0 "ومن ثم انقر زر 
"استمر ۵ں ا٤ہCo‏ ".إذا کت قد وصلت لهذا الحوار من قبل واخترت حقل الاختبار "دائماً استخدم هذا الاختیار ٥٣‏ نامء Always use tis‏ "من المحتمل أن 
لايظهر هذا الحوار على الإطلاق. 

4.يظهر حوار إضافة اتصال ١0ناءم”١هع‏ 4ه لتجمبع تفاصيل الاتصال الجديد.. إذا كان حقل"مصدر البيانات ۲٤١6۴‏ ا0ء هأة0 "يحتوي على شيء ما غير 
"میکروسوفت سکول سرفر 56۷8 ا5۵ أMicrosof‏ "انقر على زر"تغيير C۸4۸9‏ " لتبديل نوع الاأتصال باستخدام الحوار المذكور في الخطوة التالثة. 

5.العودة إلى نموذج"إضافة اتصال" وقد تم ملىئ حقل" اسم المخدم8٣٠ ١4‏ 86۲۷6۲ "باسم نسخة سكول سرفر SQ Server |s†8 ۸٥8‏ خاصتك.هذه القائمة المنسدلة 
لديها نسخ مجدولة لأسماء المخدمات»ولكن إذا لم تكن كذلك. عليك إدخالها بنفسك.الاسم الافتراضي بالنسبة لسكول سرفر السريع هو اسم كمبيوترك.مع 
الا<قڪ"EX×XPRESS SQL‏ ".فإذا كان اسم كمبيوترك هو " ۷ (YSY8S7٤‏ "فاسم النسخة سيكون " "MN YSYSTEM\SQL|EXPRESS.‏ )كما مبین في الشکل 
السابق (التخطيط 3 فاسم نسختي .„((mhm\ SQLEXPRESS‏ 

6.ركب إعدادات التصديق(التوتيق)في مقطع "الدخول إلى المخدر۲۷6۲هء 18 ها صه وما ".بالنسبة لي فإني استخدم توثيق ويندوز القياسيءولكنه يعتمد على كيفية 
تثبيت قاعدة البيانات في الفصل الرابع. 

7.في مقطع "اتصال إلى قاعدة البيانات ٥ء2‏ طهاda Connect t٥ a‏ "إما اختر أو اكتب " رإهطنا"من أجل اسم قاعدة البيانات. 

8.انقر على زر "اختير الاتصال١‏ نامه اه٣‏ "للتأكد من أن العمل كله صحيح.عندما تنتهي انقر على زر "موافق 0۸ " لاإنشاء الاتصال الجديد. 

9.بعد النقر على زر "موافق 0۸ "سيتم إعادتنا إلى نموذج المعالج السحري لتركيب مصدر البيانات.والاتصال الذي عملنا على إنشاءه يجب أن يظهر الآن في القائمة كما 
يظهر في الشكل السابق(التخطيط التالث). 

0.اللوحة التالية تسأل فيما إذا سيصبح مصدر البيانات هذا جزء من الإعدادات القابلة للتركيب من أجل هذ lلaشرaع this data source should become part‏ 
the configurabاe settings for this project‏ fد.سندخل‏ في ميزات الاإعدادات الخاصة بالفيجوال بيسك في الفصل 14.ولكن الآن »عليك فقط قيول الافتراضي 
والنقر على "التالي×مN‏ ". 

1.هذه هي الخطوة الأخيرة في إنشاء مصدر البيانات.تري اللوحة النهائية قائمة بميز ات البيانات الناتجة في قاعدة بيانات المكتبة.افتح تفرع الجداول ك#اطة1واختر " 
Activity‏ "كما هو مبین في الشکل التالي. ومن تم انقر "إنهاءءاہ آ۴ ". 
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Data Source Configuration Wizard 


Lb Choose four Database Objecis 


Which database objects do you want in your dataset? 


Î Author 

I BarcodeLabel 
LI BarcodeLabellterm 
IE BarcodeSheet 


I CodeûutharT ype 
I CodeCopyStatus 
2] 1] CodeLocation 
LIE CodeMediaT ype 
IE CodePatronGroup 
I CodeSeries 

I Broupdetivity 


DataSet name: 
LibrapD ataSet 


ent > Finish ] Cancel |‏ 
راجع لوحة مصادر البيانات المبينة في الشكل التالي.فهي تتضمن على مصدر بيانات" ا56هاة0ر۲ه۲طنا"مع وصلته إلى جدول " Activity‏ ". 


Ûalta Sources 


E |aã] LibrayDataSet 


a REME 


على أية حال ما هو مصدر البيانات؟إنه ببساطة وصلة إلى قسم في قاعدة بياناتكءتم إنهاءه في كائن دوت نت نموذجي.والآن هو جزء من مشروعك وبإمكانك استخدامه 
للوصول لابيانات في جدول " را۸۷ "من خلال كود مشروعك.أو بواسطة "السحب والاإسقاطمه۲ ك-0٣‏ ه-وه۲ك " .في لوحة مصدر البيانات»ستجد المدخاة" 
Activity‏ "ولها قائمة منسدلة فعلية.اختر "تفاصيل" من القائمة»وكما هو مبين في الشكل التالي.(يجب أن يتم عرض سطج الفورم1 ۲۳1١٠۴من‏ أجل هذا العمل). 


Data Sources E3 


س ا ا تتا 3ا 


Data riy iam 
Details 


[Morne] 


Customize... 


أخيراًاسحب واسقط مدخلة ا۷ا علی سطح ۲۳۹٥۴.وعندما‏ الاستمرار»ستضيف الفيجوال أستوديو مجموعة من الأدوات للفورم ز اند العديد من الأدوات التي ليس 
لديها واجهة مستخدم interface‏ use-0nہ‏ تحت الفورم تماماً.(شاهد الشكل التالي). 
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ID: 
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laî] LibraryDatašet ا‎ dcliyilyBindingSource 1 ActivilyT ableûdapter f TableûdapterM anager FL ActivilyBindinglavigator 


٤ 


۳ Error List َ Immediate Window 
Ready BE Ti 2924141 : 


بمجرد السحب والاإسقاطءتضيف الفيجوال أستوديو جميع الأدوات الضرورية والوصلات ليدور نموذجك ضمن التوربين المشحون لمحرر جدول " رأااناء۸".جربه الآن 
بالضغط على المفتاح ۴5.في البرنامج المشتغل.تستطيع استخدام تحكم الوصول للسجلات كما في تخطيط برنامج ميكر وسوفت أكسس ودلك للتنقل بين السجلات لجدول " 
والناA"(الأسهم‏ في أعلى الفورم).تستطبع أيضاً تعديل القيم لكل سجل.وإضافة سجلات جديدةأو حذف سجلات موجودة(ولكن أعد تخزين جمبع الأشياء لما كانت عليه 
ءحيث أننا سنستخدمها فيما بعد).تكلم عن القوة .البساطةء الاسطر غير الموظفة !فمن يريد أن يدفع لميرمجين مثلنا عندما تستطبع الفيجوال أستوديو فول كل هذا لك.؟ 


في الحقيقةء إن كل ما تعمله الفيجوال أستوديو ليس بالكثير.حيث أنها تستخدم ميزة تدعى"تحزيم البيانات‌و” ۵اط 02a‏ " لربط حقول الفورم مع مصدر البيانات(جدول 
قاعدة بيانات المكتية).إن تحزيم البيانات هو ميزة جاهزة ضمن أدوات نماذج ويندوز تسمح لهذه الأدوات ويشكل آلي عرض وتحرير القيم من مصدر البيانات المصاحب» 
متل قاعدة البيانات.ويتم تصنيف (فر ز)الجميع من خلال خاصيات الاأداة.اختر أداة ×ه8×٠ ١4٣٠۲‏ اا۴ المضافة لنموذج هذا المشروع»ومن ثم تفحص خاصياتها.في 
الأعلى تماما توجد خاصية مسماة"حزم البياناتءو”iك‏ ”88ا02 "وهي خاصية نصية جزئية تحتوي " ActivityBinding Source - FulIN ame‏ "مشیر إلى 
الاداة ActivityBinding Source‏ التي ليس لها واجهة مستخدم والتي تم إضافتها بواسطة الفیجوال أستودیو وبشکJ‏ Îلي.‏ وlڈlaةActivityBindingSource gê.‏ 
دورهاءتحتوي مرجع إلى الكائن S6هاة۷0هإطاا‏ (مصدر البيانات هءإuهء‏ واه الذي عملنا على إنشاءه سابقاً).يتصل مصدر البيانات إلى مخدم سكول سرفر SQ)‏ 
.Server‏ ومنه إلى قاعدة بيانات المكتبة م25 ههل رإجإطاا وأخيراً إلى اlنجدوJ‏ Activityوûم .FullName ala>‏ 

إذا عملت على إحصاء جمبع الكائنات المضمنة في علاقة تحزيم البيانات هذه »تصل إلى ما يقارب 238.ء5كائن متمايز.لاتتعجب من كون الفيجوال أستوديو تقوم بعمل 
الكتير لأجلك.يوفر تحزيم البيانات الكثير من الراحةءولكنه يأخذ منك الكثير من التحكم والتطوير.على الرغم من أن هناك خاصيات وأحداث تتبجح لك إدارة سمات تحزيم 
البيانات وعمليات التحديث الخاصة بهاءفإن معظم الكود الأساسي يكون مخفي بعيداً داخل أقسام تحزيم البيانات للدوت نت.يمكن أن لا تمسه» أو تشوهه»ومجرد كونه كذلك 
فإنه سيء.فمعتقدي:الير مجيات الجيدة تتضمن تحكم(سيطرة )أعظمية للمطور»وتحكم أقل بالنسبة للمستخدم. 

كجزء من عملك كمطور توفير بيئة مصنوعة بشكل متقن للمستخدم من أجل الوصول للبيانات الهامة.وهذه المتطلبات التي لديك تتحكم بتجربة المستخدم من خلال كودك 
المصدري.على وجه التخصيص,»ستؤجل الكثير من ذلك التحكم إلى تحكم أخر عندما تستخدم أدوات أخرى خارجية.طالما أن هذه الادوات تسمح لك بالتحكم بمعرفة 
المستخدم لمستوى تكون راض عنه.هذا عظيم.ولكذني دائماً أشعر بالاحباط من تحزيم البيانات»ما عدا وقت تنفيذ عرض بيانات للقراءة فقط من قاعدة البيانات.ميزات 
مشابهة كانت في الفيجوال بيسك لوقت طويل وقبل أن تصل الدوت نت.وهذه الميزات قد تم جعلها صعبة بالنسبة للمطور من أجل التحكم بتفاعلات البيانات المتنوعة على 
الفورم. 

لحسن الحظ إذا كنت تتجنب ميزات تحزيم البيانات.فإن الفيجوال بيسك ستمرر لك مسؤولية إدارة جمبع التفاعلات بين قاعدة البيانات والمستخدم. 


الاتصال مع قاعدة البيانات بنفسك هو بالتأكيد أكثر من عمل سحب وإسقاط مصادر البيانات. 


الخطةة الأولى غلى الطريق إلى تفط خاة انك بالفانات هى الاتضال إلى قاعة المانات: اكا تصن لهال كت ف اك A56‏ ا على رة اة 
بنصوص الاتصال المستخدمة في ۸00.٤۲‏ بشكل عام نصوص الاتصال كو”ذ٣†ء‏ 0ناءمnnده‏ متشابهة.من المحتمل أيضاً أنك تعرف أنه من خلال نصوص 
الاتصال تحفظ ميكر وسوفت لجام محكم ١أ٠٠‏ ٤وا‏ على مطوري ويندوز.وهي ليست بهذا التعقيدوهي لاشيء أكثر من نصوص وسيطات مفصولة بفاصلة منقوطة.ولكن 
الوسيطات 6٠١5‏ "ه٣‏ همالتي يجب أن تضمن»وتنسيقها الدقيق هو قوام عنوان تفسيري |۴٣۵‏ ؟ه لاء . مستندات ميكر وسوفت المضمنة 180١‏ مع الفيجوال 
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أستوديو توفر بعض الأمتلة لنصوص الاتصال.ولكن لیس مع الكثیر من التفاصیل.یوفر مصدر ثالث ° /0ع.5 7517/۸9 110 NW. c0۸ 8C‏ آیضا عدد ضخم من 
الأمثلة عن تنسيقات نصوص اتصال صحيحة. 
نص الاتصال الذي سنستخدمه للاتصال إلى قاعدة بيانات المكتية.ولحسن الحظ ليس معقد بإفر اط إذا استخدمت تسجيل دخول ميكروسوفت ويندوز الخاص بك للاتصال 
إلى قاعدة البيانات. النص التالي سيوفر احتياجاتك(كسطر واحد غير مفصول) 
Data Source=/nstance_name;lnitial Catalog=Library;lntegrated Security=true‏ 

بالنسبة لنص الاتصال الذي عملت على بناءه للاتصال مع قاعدة بيانات المكتبة هو التالي: 

Data Source= MHM\SQLEXPRESS;Initial Catalog = Library;Integrated Security= True 
باسم بنسخة مخدم سكول الخاص بك أو مصدر البيانات.نص الاتصال الذي عملنا على بناءه سابقاً‎ /75147٥6_27٩ حيث يتم استبدال‎ 
کاسم مصدر بیاناته.‎ “'YSYSTEM\SQLEXP RESS” يستخدم‎ 


لاستخدام معرف مستخدم سکول سرفر ۵۶| ٣6ں S۷6۲‏ ا84 وكلمة المروركك١0۲سءءهم‏ .جرب التنسيق التالي: 
Data Source=/nstance_name;lnitial Catalog=Library; User ID=sa;Password=Xyz‏ 


بالطبعءاستبدل معرف المستخدم0| #۲عں (#هء)وكلمة المرور ١5«W0۲ءهم‏ 2ر») بإعداداتك الخاصة.إذا كنت تريد تضمين دعم 1۸۸8Sفي‏ اتصالك. أضف مكونات 
فاصلة منقوطة أخرى: 
MultipleActiveResultSets=true‏ 


ClickOnce-deployed öدح|و "(التي تستخدم غالبا مچ قواعد بیانات التوزبع بنقرة‎ user ہءاھcاہو بشکل مباشر غير طریقة 'نسخة المستخدم‎ Expres )S5E€( 
التي تأتي مع الفيجوال أستوديو.‎ 180۸١ التعديلات الأخرىءعلى الرغم من أنها مبعثرة نوعاً ماءتستطبع إيجاد هذه الخيارات موثقة في مستندات‎ لمعأو.)databases‎ 


استخدم نص الاتصال لإنشاء كائن هاه 8|٤٠٣ ٣‏ »ومن ثم افتح الاتصال.أنشئ تطبيق نماذج ويندوز جديد في الفيجوال أستوديو وأضف أداة زر لسطح الفورم. انقر 
مزدوج على هذا الزر للوصول إلى معالج حدث النقر.ومن ثم أضف الكود التالي لمعالج الحدث هذا. 
e Ass UmMe Ss:‏ 
Imports System. Data‏ ' 
Dim ibraryDB As New SGICI1enNE .SGlICONNECE1 ON (Data SOUECE MENN SOLEXPRESSTE & Imi EIaAlL‏ 
Catalog=Library; Integrated Security=true")‏ 
1libraryDB. Open ()‏ 


تأكد من تبديل " 1 "باسم النظام الخاص بك. فلاسم "17١‏ المبين هو اسم النظام الخاص بي.إن مقطع الكود الكامل هذا بيدو سهل جداً وأسهل بالنسبة لي من الخطوات 
العشر أو الخمسة عشرة والتي عليك إتباعها سابقاً عند إعداد وتركيب الاتصال خلال الفيجوال أستوديو. 


حالما یتم فتح الاتصالءتستطبع إصدار "اختر S۴1٤ ٥7‏ "."تحدیث ۶0۸۲ل "."حذفع 5٤1٤۲‏ "."إدراج N8٤۸١‏ "أو أية عبارة من عبارات لفة معالجة البيانات 
data manipulation language (DM)‏ أو أية عبارة من عبارات لغة تعريف البيانات (-ا051) eوu2وˆ‏ ھا definition‏ dataالمقيولة‏ بواسطة قاعدة البيانات. 
يحضر الكائن ٤٠٥٣١ ٣"2٣١‏ |وS۹عبارة‏ سكول ا5۵الخاصة بك ليتم استخدامها بواسطة الاتصال المفتوح.إليك عبارة تعود بوصف المدخلة رقم 1 في جدول راا۷أاA.‏ 

SELECT FullName FROM Activity WHERE ID = 1‏ 
إنشاء کائن 2٣۵‏ "٣٥ا٩8‏ والذي يدور حول هذه العبارة سهل.إن المشید لکائن 8٩| ٥٥٣٣2٣۹۵‏ یأخذ عبارة سکول ا8۵ ز اند .SqIConnection jil‏ 
أضف الكود التالي لنهاية معالج حدث نقر الزر السابق: 


Dim sqalStatement AS New SalClient .SqlCommand (SELECT EulIName EROM Activity WHERE ID = 1", libraryDB) 


الشيء الوحيد الباقي والذي عليك عمله هو تمرير عبارة سكول ا۵ 5لقاعدة البيانات. بواسطة الاتصال»واستخراج النتائج ككائن هل2٠‏ 14۸ة0 .حالما تحصل على 
البيانات»عالج كل سجل باستخدام طريقة الكائن ههه .إنك تصل إلى الحقول المستقلة بواسطة الاسم من خلال تجميع البنود |٠٣‏ الافتراضي.أضف هذا الكود الإضافي 
لنهاية معالج حدث نقر الزر السابق: 
Dim sqlResults As SqlClient.SqLlDataReader = sqlStatement.ExecuteReader ()‏ 
sqlResults.Read()‏ 
e (CSEE (sqlResults. Ttem( "Ful lIName")) )‏ 
E E EEE‏ اتان کی اا اچ ا 
MSGBOX (CE SEE (SIRES ULES (LEULTLNAME LL)‏ ' 
د الا عار الال ممل اا 7 
MsgBox (CStr (sqlResults!Ful lIName) )‏ 


مع أخذ كل مقاطع الكود السابقة مع بعضها يعرض الرسالة المبينة في الشكل التالي. 
WYindowsApplication Î x‏ 


Manage authors and names 


موافق 


عندما تنتهي.تأكد من أنك أغلقت جمبع الاتصالات التي قمت بفتحها.لذلك أضف المقطع الصغير التالي من الكود إلى معالج حدث نقر الزر السابق: 
sqlResults.Close ()‏ 


القصل الائ ادو قرت نت Mhm76‏ 


libraryDB.Close () 


إن إجراء تفيرات إلى جداول قاعدة البيانات يتم بكتابة الكود تماما مثل استخراج البيانات»ولكن ليس هناك حاجة "لقارئ بيانات سكول".وبدلاً من استخدام الطريقة 
.ExecuteReader‏ استخدم الطريقة N01 Query‏ ە†E×ecuوالتي‏ لا تعود بنتانج. 
Dim sqlStatement As New SqlClient. SqlCommand ("UPDATE Activity SET FullName = 'Sleeps all day'" & "‏ 
WHERE ID = lT iEBEGEEVDE)‏ 
sSqlStatement.ExecuteNonQuery ()‏ 


إن للسكول سرفر 2005 ميزة مريحة بحيث تعود بحقل مفرد من سجل جديد منشئ بواسطة العبارة "دراج ٧8۴۴۲‏ ".إذا راجعت تصميم قاعدة بيانات مشروع 
المكتبةسترى أن الحقول 0افي عدة جداول يتم توليدها بشكل آلي. 
تقليدياًءإذا أردت استخراج حقل 0ابشكل مياشر إلى سجل جديدءعليك أولاً إدراج N8٤۸١‏ |السجل »ومن ثم إجراء عبارة "اختر ٤٥١‏ ٤اS۴"منفصلةء‏ 


العودة بحقل 0| لسجل جديد.: 
INSERT INTO CodeSeries (FullName)‏ 
VALUES (‘Children"s Books')‏ 
SELECT ID FROM CodeSeries‏ 
WHERE FullName = 'Children"s Books'‏ 


مخرجات سكول سرفر المدرجة تضم كل من هاتين العبارتين في إجراء وحيد : 
INSERT INTO CodeSeries (FullName)‏ 
المخرجات المدرجة لحقل 0|. 
VALUES (‘Children"s Books')‏ 
عندما يكتمل الاإدر اج |5٤۸١‏ ءيعمل سكول سرفر على إرجاع حقل 0اكمجموعة نتيجةاهء االاءه؟ ءتماماً كأنك أصدرت عبارة "اختر ١٨٥٤1ا٤S"منفصلة.إن‏ طريقة 


ExecuteScalar‏ لكائن أمر سكولك”ة"۳١۳١٤|ا8۹‏ هي طريقة بسيطة لاستخراج قيمة مفردة من استعلام سكول. 
sqlStatement = New SqlClient. SqlICommand ("INSERT INTO CodeSeries (FüullName) " & "OUTPUT INSERTED. ID VALUES‏ 
CERNE ES EOOKS J ( IBDEABYEEN)‏ 
Dim newID As Integer > CInt (Sq1lStatement .ExecutesScalar () )‏ 


يمكن إجراء المداولات ”٠ا‏ هو” 7/4 "الجميع أو لاشيء"عير عبارات سكول متعددة.حال البدءءإما يتم إصدار جميع عبارات سكول ضمن سياق المداولة المكتملة. أو 
لايكتمل أي منها.إذا كان لديك 10 تحديتثات ك٠اةهمدالبيانات‏ يجب أن يتم عملهاءولكن قاعدة البيانات فشلت بخمسة منهم»تستطبع التراجع )هط ااه عن المداولة 
بالكامل.تعكس 5ه5٣۷6٠٠قاعدة‏ البيانات العبار ات السابقة.وتعيد تخزين البيانات لما كانت عليه قبل أن تبدأً المداولة.(ولكن تحديتات من مستخدم أخر لا تتأثر بالتراجع).إذا 
نجحت جمبع العبارات»تستطيع تنفيذ /0/77/77 المداولة ١0اأءةءهء)‏ بالكامل»وجعل كل تغيرات المداولة تابتةا ١6١/2٠۲٠م‏ .بالنسية لقواعد بيانات سكول سرفر 
٧:841 Server databases‏ يتم إدارة المداولات من خلال موفر الکائن ۲٤٥٣‏ ‰٣/۲۲۵او8‏ .مثل میزات ۸00.٤۲‏ الأخرى فهو سهل الاستخدام.تبدأ المداولة 


. connectionJlصill‎ leBegin Transaction ةةıرط¦فJ|l‎ ءleدتږlڊ‎ 
BUDE GEOMLECSEE AS SOLEIL LONE. SIAL LEARNSACEIODM 7 DEAE VDE BEGINLEANSACEEION O) 


لتضمين عبارة سكول في المداولة. أسند كائن نامء ه٣٣او8إلى‏ خاصية "lلمlglة .SqlCommand jill " Transaction‏ 
sqlStatement.Transaction = atomicSet‏ 
ومن ثم استدعي الطريقة المناسبة على الأمر.عندما تكتمل جميع الأوامر»استخدم الطريقة ان٣۳0‏ للمداولة٥‏ ناء ج١ا‏ لجعل التفیر ات ثابت ۳2٣6۸٤‏ ِم . 
atomicSet. Commit ()‏ 


إذاءبدلاً من الإدراج»احتجت إلى إجهاض المداولة” هنا هء١‏ ه٣‏ .استخدم طريقة "التر اجع )عهطاامR‏ " 
alomiesel Rol Ia)‏ 


الاصدار ۸00.٤1‏ المضمن مع النسخة 3.5من إطار عمل الدوت نت(وهي النسخة التي تأتي مع النسخة الحالية أي فيجوال أستوديو2008)تتضمن مكونات 
جديدة:كينونة إطار Joc‏ İڏg‏ ڌو iتFramework entity-relationship modeling too|ةigiıكJl ةةڵle ةجفمنi ölدİ «jج . ADO.NET Entity‏ Part.جزء‏ مولد 
الكوداهاa code gener‏ artم‏ .وهذه التقنية الجديدة تساعدك على صنع عروض بيانات منطقية Ws‏ ع۷ هأهك اهءأوه!| للبيانات المخزنة في قاعدة البيانات العلائقية 
الخاصة بك أو مصدر البيانات. 

تتيح لك كينونة إطار العمل )0۲ Entity ۴a W‏ تصميم تلاث أنواع من الكائنات بالاستناد على بياناتك المخزنة:الكينونات sع/ا/٤٠/٠‏ (مشابهة للجداول )ءالعلاقات 
psأe/ati0nsh/‏ (ر وابط قاعدة البيانات).و مجموعات الكينونة ئاهء را۸٠‏ (الكينونات المتعلقة(ذات الصلة)).كل نوع يتم تمثيله بواسطة كائنات تعرض أعضاء قاعدة 
بياناتك الجوهرية(القاعدية) في صيغة أكثر برمجية١5۸0ه؟‏ ماص ص raوroام more‏ هص in‏ .على سبيل المثالء تستطيع تصميم كينونة كائن تمثل جدول في قاعدة 
بياناتك. وأعضاء كائن يمكن أن تمتل الحقول كلاه اأفي سجل وحيد ١١0ء۲۴‏ #او”ء.إنها تبدو مثل بعض الميز ات المبنية ضمن كائن جدول البيانات ماطة 014١‏ لآدو 
دو نت ۸20.٤١‏ .إن ما يجعل كينونة إطار العمل مفيدة جداً هو التالي©1)فهو يشيك البيانات الفعلية بالعروضW5ها۷‏ .(2)إنه دعم لوراثة الكينونة رانأ" 
inheritance‏ (3)ولها المقدرة على التصرف کموفر .A۸D۵0.N٤٣‏ 


تشبيك البيانات مشابه لإنشاء "عرض سه۷ " في قاعدة بيانات علانقية تظيدية.تستطيع إنشاء كينونات والتي يتم تركيبها ببعضها من امتداد سجلات مصادر متعددة عبر 
جداول قاعدة بيانات متعددةءاطها م2 طهاaه‏ مامtiاuص‏ .وهذا يتضمن عروض أباء-أبناء لابياناتءW#ا۷‏ ١ا۸٥-أ١ه۲هم‏ .تستطيع إنشاء كينونة "طلبية 0۲١۴۲‏ " 
ولتي فشر الى كل مى سكل الطلة 6۲96۴ ال في وة مط “الطلهة روون اذك المحة في اة مك وة ايا هة اة ااكة كه 
استعلامي مفرد. عندما تطلب بيانات من خلال الكينونة الجديدة.ليس عليك تعليمها كيفية ربط وإقامة علاقة سببية ومنطقية بين القطع المصدرية المتنوعة للبيانات كل مرة. 


القضل العات ر ادو فرك تت Mhm76‏ 


حالما يكون لديك كينونة معرفة.تستطبع تمديد تركيب الكينونة من خلال الوراثة.مثلاًءمن المحتمل أنك تريد إنشاء كينونة تدعى ٠١٠۲٠20۲۲‏ معتمدة على كينونة"الطلبية 
"der‏ الأصلية. وإضافة أعضاء بحيث تقتفي أثر البيانات المخصصة لتلبيات داخلية.يمكن لهذه الحقول الجديدة أن تكون جدول مخصص.يتم إطلاقه بواسطة إشعار 
منطقي 80٥01۴2۸‏ على الجدول الرئيسي للطلبيات.ولكن هذا ليس بالقضية المهمة:من المستطاع إخفاء الجميع بواسطة منطق الكينونة نفسها.عندما تطلب حالة(نسخة)من 
0rderاnternaا.فإنها‏ ستعرف تماما أنك تعني فقط النوع المشار إليه والمخصص داخلياً للطلييةء وليس الطلبيات القياسية. 


حالما تكون قد أنشأت كينوناتك ومنطق التشبيك المتعلق بهاءتستطبع "الاتصال"إلى الكينونات وكأنه تم تخزينها في قاعدة بياناتك الخاصة.بدلاً من الاتصال إلى سكول سرفر 
والاستعلام عن الجداول مباشرةءفإنك تتصل إلى السياق المشبك والاستعلام على عرض المنطق الجديد لبياناتك. 

بعض هذه التقنية والتي سأناقشها في الفصل 17لديها صيغة قريبة للكود المركز على كينونة إطار العمل للاوت نت ءولكن ويشكل خاص ستستهدف بشكل خاص سكول 
سرفر.إن كينونة إطار العمل لأدو دوت نت هي الطريقة الرئيسية لاتصال تقنية لينكو الجديدة للدوت نت إلى قواعد بيانات غير التابعة لميكر وسوفت مثل أوراكل و 082. 
لسوء الحظءقبل عدة أشهر من إطلاق فيجوال أستوديو2008.أعلنت ميكر وسوفت أن كينونة إطار العمل )0۲ Entity ۴۴W‏ لن تكون جاهزة في الوقت الحالي من 
أجل المنتجات الرئيسية(متل أور اكل).فقد تم نقدها لبزوغها كإصدار منفصل بعد عدة أشهر من إصدار الفيجوال أستوديو.ويمكن أن يكون أو لايكون المنتج النهاني متاح عند 
قراءتك لهذه الأسطر. 


من المحتمل أن أكتر من %50 من كود مشروع المكنبة سيتضمن الوصول المباشر لقاعدة البيانات» أو معالجة البيانات المستخرجة من خلال ۸00.۸ باستمرار 
اا انات أ اك انات فة عاي اله اماف رك كدة نوا ماعا ال عاف أن الك مى الكت كا ا كةو هرغ فا اال 
سيحاول التر كيز على بعض الاأساسيات»والكود المعياريعأهام۲هااهط . 


لكود مشروع المكتبة مراجع لعدة فضاءات أسماء هامة في الدوت نت مثل ”6اSysو System.Windows.F or ms‏ .و Microsoft.VisualBasic.مھما‏ يكن.لیس له 
حتى الآن مرجع لأي من فضاءات أسماء آدو دوت نت ۸00.٤‏ . (تذكر أن "التزويد بمرجعو١ء١٠۲ه؟هء‏ " يعني إمكانية الوصول إلى مكتية الربط الديناميكي 
للدوت نت اا0 ..E۲‏ في المشروع واستخدام أنواعها في كودك) قبل استخدام فضاءات الأسماء هذه في الكودنحتاج إلى إنشاء مراجع(أو مؤشرات)لها.وهذا يتم عمله 
من خلال نافذة خاصيات المشر و ع۲۴5 #م١١م‏ اعهزهآإم .في تيويب"المراجع ع٥ R۴۲٠ ٠‏ ".سترى قائمة بالمجمعات التي تم الإشارة إليها كمراجع سابقاً في 


تطبيقك(شاهد الشكل التالي). 
Unused References... Reference Paths...‏ 
Debug References:‏ 
Reference Name Type Yersion opy Local Path‏ | ` 
REENEES system NET 2.0.0.0 False CHWINDOWSIMIcrOSaFt,NETIFramework|¥2,0,5072715ystem, dll‏ 
System, Zore NET 3.5.0.0 False Ci\Program Files{Reference Assemblies Microsoft Frameworki¥3,5\System, Core, dll‏ 
Resources System, Data NET 2.0.0.0 False CAWINDOWYSNMicrosoft, NETI{FrameworklyY2,0, 50727 System, Data, dll‏ 
System, Data, DataSetExtensi.,. .NET 3.5.0.0 False CilPrograr Files\Reference Assemblies Microsoft FrameworkiY3,5\5ystem, Data, DataSetExtensions dll‏ 
Services System, Deployment NET 2.0.0.0 False CAWINDOWYSIMicrosoFE, NETIFrameworklY2,0, S0727 \System, Deployment, dll‏ 
System, Drawing NET 2.0.0.0 False CH WINOOWSMicrosoft, NETIFrameworkl¥2,0, 5072# 1System, Drawing, dll‏ 
Settings System, Windows, Forms „NET 2.0.0.0 False CAWINDOWSIMicrosofFt, NETIFrarmeworkiy2,0, S0727 \SYstem, Windows, Forrns, dll‏ 
System, #rml NET Z.0.0.0 False CHWINOOWSMicrosoft, NETIFrameworklY2,0, 5072# System, rm, dll‏ 
Sting System, rl, Linq NET 3.5.0.0 False CiProgram Files\Reference Assemblies MicrosofHFrameworkl¥3,515ystem, Xml, Ling .dll‏ 
ly Extensions‏ 
Security‏ 
Publish‏ 


لإضافة مرجع جديد »انقر الزر "إضافة ۸۵۵ "الموجود تحت القائمة مباشرةءواختر مرجع.فإذا طلب منك نوع المرجع الذي سيضاف.على نموذج إضافة مرجعءسيكون 
تبويب دوت نت فعال سابقاً.ومن المدهش رؤية كيف تم تثبيت العديد من مجمعات الدوت نت على نظامك سابقاً.ولكن لا تجلس وتحدق کالابله»اختر كل من 
System.Data‏ و اXm. System‏ من قائمة المكونات»ومن تم انقر الزر موافق0©K‏ .وبالتالي ستتضمن قائمة المراجع الآن في خاصيات المشروع كل مكتبات فضاء 
الأسماء المختارة. 

نستطيع الآن الإشارة إلى فثات في فضاء الأسماء هأة0.”٠ءاءرS‏ مباشرةً.ولكن كتابة هة 0.١1#ءر8‏ قبل كل استخدام لفئة ذات صلة بالبيانات data-related class‏ 
سيسبب الملل.نستطبع نشر العبارات ”هة 0.٠#اءرS‏ ءأامم |“ لجميع الملفات في المشروع.ولكن توفر الفيجوال أستوديو حل أكثر مركزية.بما أنه ما يزال لديك 
تبويب المراجع ءهء e۲٠۸‏ Rمفتوح»انظر‏ للأسفل إلى مقطع "فضاءات الاأسماء المجلوبةsئعءةمكم”ص‏ هم dمortمصا‏ ". تشير قائمة الاختيار الضخمة إلى أي من 
فضاءات الأسماء سيتم إحضارها بشكل آلي على كامل تطبيقك.وفضاءات الأسماء هذ لا تحتاج إلى عبارات كأامم "| مفصولة في كودك.ولكن يتصرف كودك وكأنك قد 
عملت على إضافتهم على أية حال.والآن ارجع إلى الأعلى واختر صندوق الاختبار بجانب مدخلة هأة0.٠ءاءرS‏ في هذه القائمة.ومن ثم أغلق نافذة خاصيات المشروع 
.project properties‏ 

معظم الكود الجديد لهذا الفصل سيظهر في الملفط۷ 66/7٥/2/.‏ .لذلك افتحه الأن.سنستخدم متغيران على مستوى المشروع(عام) لاإدارة اتصال قاعدة بيانات رئيسية إلى 
قاعدة بيانات المكتبة.المتغیر الأول 08/ 5۲2ا »وهو کائن S٣60۸‏ يستخدم نص اتصالنا لقاعدة و s٣٣‏ ۸٥ناconnec‏ بيانات المكتية.الكائن 


الفصل العاشر:آدو دوت نت Mhm76‏ 


Hold Transaction‏ ذو الصلة بالمتغير السابق سيحفظ S٣r sation‏ عندما تكون المعاملة قيد التنفيذ.أضف هذين السطرين إلى الوحدة البرمجية .لقد عملت على 
وضعهما قبل الطريقة الموجودة ٥٠١٠۲٠٠۸۲‏ تماماً. 


EUS ISEAEVDS AS SVSEOM DaEa. SOLICITED E. SGLCEONNEe CEI OR 
EUGITGS HOLALEANSAC EON AS SYSEeM. WAA. SALE UNEN E. SOLE EAMS AEE OM 


بما أن مشروع المكتية سيعتمد کثيراً على قاعدة البيانات.سنبني كائن ١٥ناءه١١٠|S۹عندما‏ بيدا التطبيق بالتشفيل . 


يحتوي الاجر اء #ءaطهامداءممCon‏ جمبع الكود الضروري لانشاء هذا الكائن.أما الآنءفلقد عملت على كتابة فقط نص الاتصال s٣9‏ ١i0اممconn‏ في هذا 
الروتين.في الفصول اللاحقة سنعمل على تضمين معلومات الاتصال كجزء من نظام الإعداد.أضف الروتين التالي إلى الوحدة البرمجيةاة۲٠٠٠6‏ .وتأكد من تفير 
المرجع(المؤشر ۱۲5۲57٤۷‏ ) لما هو ضروري على نظامك الخاص كما ذكرنا سابقاً. 


Public Function ConnectDatabase() As Boolean 

Connect to the database. Return True on success.‏ ڪج ا 

Dam Connecti ONSEEING AS SEEING 

WATE Fal ae.‏ جص ا 

HOLATLEaANR SAC EON — NOCENING 

٣ کے‎ Build Lhe eonnectEi On SEEING. 

' !!! WARNING: Hardcoded for now. 

connectionString = "Data Source=MYSYSTEM\SQLEXPRESS;" & "Initial Catalog=Library; Integrated 
Security=true" 

Attempt to open the database.‏ ا 


HiIBDEar VDB Nev SGLCLIEeNE SOLCORNNEC E1 ON (CONNEEE LOR SEE IMO) 
LibraryDB. Open () 

Catch ex As Exception 
GeneralError ("ConnectDatabase", ex) 
Return False 

End TEY 

Success.‏ صت ا 

Return True 

ENG EURNCGE TSN 


هذا الروتين هو الروتين الرئيسي للمشروع وهو حدث التطبيق العملي مناه ١_S‏ i0هءiاممMyA‏ .من ملف الكود المصدر ي ل ۷b‏ .5ئ 07E ve‏ icati/اp‏ .من أجل بناء 
كائن الاتصال لدى بداية تشغيل التطبيق.أضف الكود التالي لنهاية معالج الحدث هذا. 

Er iIvate SUS MYABPIieEaEi On SEAarEUSKEYVSl Sender AS OONect, EVVSl € AS 

Microsoft.VisualBasic.ApplicationServices. StartupEventArgs) Handles Me.Startup 


End SUS 


عندما يخرج المستخدم من تطبيق المكتبةءفإن الكود سيستدعي الطريقة ۳٣ه۲وه٣۴ملا”‏ ها للتخلص بشكل مناسب من كائن الاتصال.ارجع إلى الوحدة البرمجية 
./A/عGen‏ وأضف تلك الطريقة. 
BUDITE SUS Clea USErOSEAM‏ 
اه که اا د کک ل 
Om HE BOE KES UME ESSE‏ 
LibraryDB.Close ()‏ 
Cl SUS‏ 
لتبسيط الاشياء»نستدعي هذا الروتین من معالج حدث التطبیق My Applica ti0 ۸_S u٥ Ww‏ .ار جع إلی ملف Evens. ۷b‏ ^pp//cati0o.و‏ ضف التالي: 
Private Sub MyApplication Shutdown (ByVal sender As Object, ByVal e As System.EventArgs) Handles‏ 
Me.Shutdown‏ 
EEN SEE REE‏ 1 
CleanUpProgram ()‏ 
End Sub‏ 


بعد أن تم تأسيس اتصال قاعدة البيانات»حان الوقت لعمل شيء ما به.تنفذ الروتينات الأربع المتمركزة في البداية الكثير من الكود الذي تم مناقشته سابقاً:إنشاء قارئات 
بيانات 26۲5ء۲ هاه وجداولءهاطها .ومعالجة كود سكول ا5۵ العام.أضف هذه الروتينات إلى الوحدة البرمجية كما يلي: 
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DLT 
Dim 


US NOE 
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O ES 
EGHAM. COME E J 
Hold EEE SEA E ENON > OER 

End SUS 


BODIE SUD LEANSACEELONROLIBaAEC E) 
۳ کک‎ Ignore if there is no transaction. 
. حالهة جاح وجود داو‎ E 
On Error Resume Next 
TE EoOldTrEansaetion US Mochi no) Then EEEUEN 


0 Rollback the transaction. 
ا ا‎ 
HoldTransaction. Rollback () 
HoldTransaction = Nothing 
ERG SUS 


لنشرح هذه الروتينات السبع: 


تقديم عبارة سكول .لاستخراج نتائجها من قاعدة البيانات» ووضع جمبع النتائج في كائن جدول بياناتهاط ة۲ هه٥0‏ .يتصل الكائن ثSq|DataAdapter|إلى‏ 
ata Reader‏ اSqمن‏ خلال جدول ıllيانات .DataT able‏ 


تقديم عبارة سكول.لاستخراج نتائجها من قاعدة البيانات» والعودة بكائن قارئ بيانات سكول 80214۸٠406۲‏ المصاحب . 


إرسال عبارة سكول إلى قاعدة البيانات للمعالجة. 


إرسال عبارة سكول إلى قاعدة البيانات للمعالجةء والعودة بقيمة لنتيجة مفردة. 


بدء مداولة جديدة. 


تنفيذ المداولة.وجعل جميع التغير ات ثابتة ۸۲ ۵۲۳2۸۵م. 


السير بطريق الرجوع عن المداولة.وعدم عمل أي تغيرات والتي كانت جزء من المداولة. 

ولا واحد من هذه الروتينات يتضمن كود معالجة خطأً خاص بهاءفهي إما تقمع (تخمد) الأخطاء بالعبارة"عند الخطأً تابع التالي"»أو الاعتماد على الروتين المستدعي 
لاصطياد الأخطاء.وهذا يتبح لاروتين المستدعي القيام بفول معين بالاعتماد على نوع الخطأً الناتج.جمبع هذه الروتينات متشابهة إلى حدٍ بعيد مع بعضها البعض. ففي كود 
الروتين 26۴۲ء Creat eR‏ »جزء واحد مهم وهو استخدام الكائن ۸٠ناءةء‏ ه۲۲ ١اه‏ عند تكون المداولة قيد التنفيذ. 

If Not (HoldTransaction Is Nothing) Then dbCommand.Transaction = HoldTransaction 


يتضمن بناء عيارات سكول يدوياً الكثير من معالجة النصوص.ز ائد المعالجة الشرطية لها عدة مرات عند احتمال فقدان البيانات.على سبيل المثال»إذا أردت تخزين قي 
نصية في قاعدة البيانات» عليك تحضيرها للاستخدام من قبل عبارة سكول(معالجة خاصة من أجل علامات الاقتباس المفردة)ءولكن إذا كانت قيمة النص ذات طول صفري 
thوenاzero.‏ فإنك تمرر الكلمة في العبارة عوضاً عن ذلك.جميع هذه التحضيرات للبيانات يمكن أن تعرقل كودك.لذلك لما لا تكتثفها(تجعلها مركزية)؟الروتينات الثمانية 
في هذا المقطع إما تحضر البيانات للاستخدام في عبارات سكول أو تضبط البيانات المستخرجة للاستخدام في التطبيق. 
PubIIE HunceE1on DECOMSO(BVRet whichEield AS COMBOBOX) AS SEEING‏ 
N ELS E N ES o E‏ 
Dim listItem As Library.ListItemData‏ 
ل ل ا ا ا ا 
If (whichField.SelectedItem Is Nothing) Then Return "NULL"‏ 
listltem = Clype (whichField. SelectedItem, Library.ListltemData)‏ 


EN CECE‏ ا ا وی اک کک رن 


If (listItem.ItemData = -1) Then 
Return NUE 
Else 
ReEUrN CSEE (LISE lL Eom . LEeMDa Ea) 
ol E E| 


End Function 


EUDILGE RUNE EAON DEDa EEBVNGSN Ore AS CEE ITN) AS SEEING 
حص ل‎ Prepare a date for insertion in a SQL statement. 
1E (Lrim(oriolex te) _ >= IT) Then 
Return "NUL! 
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يأخذ الكود العددي عملهء عءأه ٠نم‏ المصاحب لبند مختار في أداة صندوق مركب ×080ط 0۳ ويعود به كنص.إذا لم يكن هناك نص قيد الاختيار أو القيمة هي -1 
»يعود الروتين ب"بدون قيمة ااNU‏ ". 


E: 


تقديم نص ما يحتوي على تاريخ منسقءوالعودة بتاريخ جاهز للاستخدام في عبارة سكول. 


تقديم قيمة تاريخ صحيحةءوالعودة بتاريخ نصي جاهز للاستخدام في عبارة سكول. 


العودة بعدد عشري من مجموعة نتيجةءحتى ولو كان الحقل يحوي قيمة "بدون قيمة اال ". 
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يعود بعدد انتغر من مجموعة نتيجة»حتى ولو كان الحقل يحوي قيمة "بدون قيمة-االاN×‏ ". 


يعود بنص من مجموعة نتيجة»حتى ولو كان الحقل يحوي قيمة "بدون قيمة". 


يحضر عدد للاستخدام في عبارة سکول . 


DBText 
يحضر نص للاستخدام في عيارة سكول.راجع الكود في الأعلى من أجل هذا الروتين.فالنص في عبارة سكول يجب أن يكون محاط بعلامات اقتباس مفردة.وأي علامة‎ 
اقتباس لكي يتم تضمينها يجب أن تضاعف.‎ 


المقطع الأخير من الكود يدعم التحديث والاستخراج السريع لقيم نظام التركيب الواسع المخزنة في جدول قيم النظام مںاة1#"۷ءر8لقاعدة بيانات المكتبة.يعود الروتين 
ueاVa System‏ 6etبالاعداد‏ الحالي لقيمة التركيب عند التزويد بقيمة الاأسم8٣4۳١۸‏ ٥1ا۷2‏ .يحدث gİ)SetSystemValue‏ يضيف» عند الحاجة)قيمة تركيب مسماة(أو 


محددة).كل من هذين الروتينان يظهران في الوحدة البرمجية ا۴۲2"ه6. 
AS SEring) AS String‏ 


FubDlTE Sub AS CERIN 


Dim 
DA 
TEV 


ME (CIDE 


Cd E 


AC HEN 
و ا‎ 


الروتين عuاة۷”ءاءرSاء6واضح.فهو‏ يستخرج ببساطة قيمة مفردة من قاعدة البيانات. 

على الروتين #ںاهة۷٣ءءرS؟۲هSأولاً‏ اختبار فيما إذا قيمة التركيب(الاعدادمںاج۷ 0۸ااهإuوا؟مهء‏ ) التي ستستخدم للتحديث موجود مسبقاً في قاعدة البيانات.فإذا 
كانت كذلك(آي موجودة)فإنه يعدل السجلات.وإلاءفإنه يضيف سجل كامل جديد.لتحديد فيما إذا كان سجل موجود أم لافالمطلوب إحصاء السجلات التي تطابق اسم قيمة 
النظامء ١٣2٠٣6‏ عماج۷ ۳ءء .ويستعلم(يستفهم) هذا الروتين عن قاعدة البيانات من خلال الطريقة ٣۲ا٠‏ ۸ا۹؟ءاuءه×ع‏ .والتي تعود بقيمة وحيدة من استعلام 


yاصuو.في‏ هذه الحالةءالقيمة هي عدد السجلات المتطابقة. 
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کما تری استخدام الروتين ueاة۷ءاءر6۲8سهل.لذلك‏ لنستخدمه الآن. ار جع إلى مرlلجچ‏ حدjث Events. vb MyApplication_Startup‏ icationاApp‏ وأضف 
التالي إلى نهاية معالج الحدث: 


بين فترة وأخرى.أجد من الضروري تعديل تركيب قاعدة البيانات إلى حد أن الإصدارات القديمة من التطبيق إما لم تعد تعملءأو أن تسبب البيانات الرئيسية وجع راس. 
ولمنع هذاء عملت على إضافة إعداد إصدار قاعدة البيانات”هاء٠۷هءهطهاه0‏ .واستخدام مقطع هذا الكود من أجل الاختبار عليه.فإذا لم يوافق البرنامج إصدار قاعدة 
البيانات المتوقع.فإنه سيرفض التشغيل. 


الفصل العاشر:آدو دوت نت Mhm76‏ 
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Security je ¥l| 
ظا شى كتف فة كان وا الفذ فن الكف غت على لضفن اله "ف ود6 * فن كاوها اكطها ركل مو اضعا أك اا عازن‎ 
" Japanese Cooking Secresailڊlıll مثل "أسرار الطبخ‎ 
increasingly permissive moral طl والمعايير الأخلاقية |nlتllıة ڊإفر‎ informatio هveاا٥ھ4 في هذه الفترة ه۲عمن تكاثف المعلومات‎ 
على التلفاز »تبدو الأسرار نادرة.ولكن كل واحد لديه معلومات مهمة يحتاج حفظها عن الآخرين»وهذا يتضمن مستخدمي برامجك.‎ stn لarلs‎ 
لحسن الحظ بر امج الدوت نت والبيانات المتعلقة بها يمكن أن تكون آمنة عند الحاجةءإذا استخدمت ميزات الأمان المتاحة لك في إطار عمل الدوت نت.‎ 


يتضمن الأمان في الدوت نت العديد من الميزات»ولكنها تقع بشكل عام تحت ثلاث مناطق رئيسية: 


الفثات ءهءءهاوأعضاء الفئات في الدوت نت يمكن أن يتم حمايتها بواسطة الأمن المعتمد على المستخدم أو الأمن المعتمد على القواعد. ويتواجد أمن 
الوصول للکود Ce Access Sect )C۸8(‏ لحفظ المستخدمین الغیر م رخص بهم 0۲126۹۵٣اuاه"ں‏ من الوصول لميزات المكتبات الفعالة 
libraries‏ اerfuسoم‏ التابعة للدوت نت.وفقط هؤلاء المستخدمين الذين لديهم مجموعة قليلة أو خاصة من الحقوق يمكنهم استخدام هذه الميزات المحمية. 


بما أن أي واحد يمكنه أن يطور وينشر تطبيق دوت نت.فمن الهام حماية مصادر النظام من كود مؤذ.وهذه قضية كبيرة.وخاصة مع التقارير 1 
الذاهبة(الخارجة) من الهكر ز (القراصنة) والتي تستفيد من مشاكل"اجتياح الجدار " في البرمجيات الصادرة من ميكروسوفت والبائعين الأخرين.وكما أن 
"أمن الوصول للكود(۸S8ع)‏ ر٤/ءمS‏ ssعءAc‏ مهه "يحفظ الكود من الوصول لميزات خاصة بالفئة»وهذا امن يتفاعل مع نظام التشغيل لحفظ 
الكود المؤذى(المحتال)من الوصول لبعض أو كل الملفات والأدلة.مدخلات التسجيل»مصادر شبكة العمل»محيطات أجهزة الكمبيوتر المركية عليه» أو 
مجمعات الدوت نت الأخرى المعتمدة على سياسات الأمن السارية)|لنافذة |لمأزعpolicies.Jg .(in-effect security‏ 


البرامج ومصادر الكمبيوتر ليست الشيء الوحيد الذي يحتاج الحماية.بعض المستخدمين ذوي الألفاظ الطنانة يفكرون أن بياناتهم ثمينة وهامة بحيث 
تستحق أن يتم حمايتها من خلال وسائل برمجية خاصة.التشفير ١0نامراء"ع‏ والتواقيع الرقمية ئمإuامہواء‏ اهأنوال وميزات تشفير cryptographic‏ 
أخری توفر دعم خاص تحتاجه مثل هذه البیانات. 

ولأن مشروع المكتبة يتفاعل مع مصادر خارجية رئيسية - قاعدة بيانات سكول سرفر- فهي تتعامل مع قضايا الأمن الخارجي»وأيضاً بطريقة غير 
مباشرة مع ۲٤۸00.Nوسياسات‏ أمن الأنظمة ءعاعاامم رااuعهء‏ mمtءرء.ولأن‏ الكتاب يركز على توزيع تطبيق عمل نموذجي .فهذا الفصل لن 
يناقش كل من قضايا الأمن الخارجي والداخليولكنه سيركز على مواضبع أمن البيانات.وخاصة تشفير البيانات. 


استيداع سر.لدى شخص أخر هي قضيةءوالتأكد من أن سر ما يأتي من شخص أخر موتثوق هي قضية أخرى أيضاً. التأكد من أنني أحصل على أفضل 
معاملة بالنسبة لتأمين السيارة هي قضية أخرى مختلفة بالكامل. 


عندما يفكر الناس بشأن التشفير ١٥أم‏ راء" هوآمن البياناترااuءهء‏ اجه »بشكل عام يركزون على سمة"حفظ الأسرارءأه۲ءهء وام مع)".إمكانية 
كتابة محتوى بشكل كودي(تحويل الأحرف إلى رموز).وحفظها بعيدة عن الخصمر٣‏ 0۷6۲52 .مع ذلك تبقى قابلة لفك التشفير من قبلك أو إرفاقها في 
وقت متأخر هو هام.مجال تقنيات التشفير بدءآً من الانحرافات عن اللفة اليسيطة وتبديل الشفرة(استيدال الأحرفك ٠‏ ٥اا‏ ں†ناطنء إهااها » المستخدمة في 
الألغاز الرمزية(المكتوبة بالر موز ءهاععام "ه۲ وهامراء ))إلى أنظمة التكويد النوعية للأجهزة التفسيرية enigma-machine-quality encoding‏ 
sءصهاءرء.البرمجيات‏ التي تمكن التشفير هي جزء من تعلمنا اليومي الآن.عندما تعمل كرت اعتماد (بطاقة ائتمان)شرائية من مواقع انترنت»فإن الفرصة 
جيدة نسيياً لأن تكون معلومات بطاقة الاعتماد خاصتك يتم تشفيرها وتحويلها إلى دقة سرية في 128- بت. 

نموذجیاً طرق التشفیر ٥۸‏ نامرا" تعمل على استخدام واحد أو أکثر من المفاتیح» ز اند توحید دوال العنونة بالکود ٥۸s‏ زاء" وہ٣/۸45۸وخوارزمیات‏ 
التشفیر 5٤/0و/ھ‏ ۸٥نا‏ مرءء”٠‏ .لتحويل محتوى دقيق ا0ء ه۷ااوہهءإلى صيغة ليس من السهل الوصول لها دون المفتاح المناسب أو 

الا صلي.التكويد المتماتل رامة۲وهامراc‏ ticمصصرSy‏ هو الاسم المستخدم لطرق التشفير ١٥اأمراء١٠‏ التي تستخدم مفتاح سري مفرد هاوہاأء 

key‏ secret.یعر‏ ف أیضاً التشفیر بالمفاتیح العامة ٣٥ا‏ م e۸٥۲‏ رع۸۔-٥//bں۶u‏ بالتشفیر الفیر متماٹل رم 9۲2٥ا‏ م۲٥ 457/76۸/٥‏ -ویستخدم زوج 
من المفاتيح لتشفير مرا هوفك تشفير امر۲ء هه البيانات.يمكن أن يتم إعطاء المفاتيح العامة لأي واحد يهتم بالاتصال معك بشكل سري.حتى من 
الممكن أن تعطي هذه المفاتيح لمنافسيك»فهي عامة. 

المفاتيح الخاصة ر۸ اةا//م المناسبة يتم حفظها بشكل آمن لتستخدمها أنت.ولن تريها لأي كان.المحتوى المشفر باستخدام واحد من المفاتيح( 
وخوارزمية التشفير)يمكن أن يتم فك تشفيره فيما بعد باستخدام المفتاح الآخر.إذا ما شفر صديقك بعض المعلومات باستخدام مفتاح عاملايمكن لأي أن 
يكون قادر على فكه ما عداك أنت.وسيتطلب مفتاح خاص بك.تستطيع أيضاً تشفير البيانات بواسطة مفتاحك الخاص.ولكن أياً كان يستطيع فك شفرته 
بواسطة المفتاح العام.سنرى استخدام هذا الإجراء الفير آمن ظاهرياً بعد قليل. 
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يساعد تشفير البيانات ضمان تكامل مقطع من البيانات»حتى ولو كانت تلك البيانات غير مشفرة.إذا أرسلت لشخص أيميل أثناء عاصفة رعديةءتوجد 
وبشكل خاص فرصة لأن يتم تبديل بعض أو كل محتوى الرسالة الالكترونية بشكل الكتروني قبل وصولها إلى المستقبل.دعنا نقول أن بعض الكهرباء 
الساكنة قي خطوط شبكة النقل حدث لان تسبب مضاعفة جملة واحدة .كيف ستعرف فيما إذا كان المؤلف يحاول صنع نقطة تذكير أو ببساطة شائية 
کمبیوتر؟. 

تضمين "اختبار الإضافة ”سء۸ءع۸ء " مع المحتوى يساعد في التعرف على مشاكل البيانات أثناء النقل.يدعى "اختبار الإاضافة uء)kءع۸ء‏ "في 
بعض الأحيان "قيمة التكر ار ٠/٠‏ ۸ئ۸ "- تأخذ المحتوى الأصلي وتمرره إلى دالة تولد قيمة مختصرة ماج۷ ١۴۲٥ء‏ تمثل البيانات الأصلية.دوال 
"اختبار الإضافة"(أو خوار زميات التكر ار 0/٤١١5‏ و/ة و/۸45۸ )حساسة جداً حتى للتغير ات في البايت المفرد ضمن المحتوى»فيما إذا تم تبديل ذلك 
البايت المفردتغير موقعه. أضيف. أو تمت إزالته من البيانات الأصلية.بتوليد"اختبار الإضافة"قبل وبعد إر سال البيانات,تستطيع التثبت فيما إذا تفير 
المحتوى بالكامل أثناء النقل. 

تمثل "اختبار ات الإضافة" تشفير غير موجه للبيانات الأصلية.من غير الممكن استخدام "اختيار الإضافة" للحصول على محتوى الييانات الأصلية.وهذا 
صحيح.إذاًويما أن الهدف من "اختبار الإضافة" ليس لتسليم المحتوى بشكل سري»ولكن تسليمها غير متغير ة.التشفير الثنائي الاتجاه 86/0/٥10 ١2/‏ 
encryption‏ هو ما تحدثت عنه في مقطع"حفظ الاسرارءأ۲6ءهS‏ وہامهه) ".إذا كان لديك مفتاح صحبح و خوارزمية صحيحة.يعيد التشفير الثنائي 
الاتجاة ٣0نا‏ مencry‏ اidirectionaط‏ تخزين المحتوى الأصلي من المحتوى المشفر. 


لنقول أنك استقبلت رسالة الكترونية تقول شيء ماءكيف تعرف أن هذه الرسالة موثوقة» أو حقيقة من مرسل معين؟في هذه الحالة. المحتوى لوحده يجب 
أن ييرهن استحقاقه الثقةر٣٤۲هساءدء)‏ .ولكن إذا أردت حقاً التحقق من المصدر»ومن غير المتاح الاتصال مع من بعث الرسالةءتستطيع توظيف تواقيع 
رقمية ك٥ااة”و/ء‏ /وا/و/ لإتبات هوية المرسل. 

طريقة وحيدة لاستخدام التواقبع الرقمية التي توظف تشفير بالمفاتيح العامة لنقل رسالة أو كلمة مرور متفق عليهاءوتمرر المحتوى المشفر على طول مع 
رسالة الكتر ونية أكير .على سبيل المتال»يمكن أن يشفر المرسل النص"أنا المرسل فلان "باستخدام مفتاحه الخاص .عندما تستقبل الايميلءيمكنك فك 
تشفير التوقيع الرقمي باستخدام مفتاح المرسل العام.إذا أنتج فك تشفير الرسالة"أنا المرسل فلان "»ستعلم أن تلك الرسالة فعليةوفي الحقيقة تأتي من 
المرسل فلان. 


تشفير البيانات وميزات الأمن المضمنة مع الدوت نت تظهر في فضاء الأسماءرمةإوهامرr.رtاcuهtem.Sءرك‏ .معظم الفثات في فضاء الاأسماء هذا 
تنفذ خوار زميات تشفير معروفة جيداً ومتنوعة والتي تم قبولها بواسطة المنظمات والحكومات كمعايير تشفير معتمدة.على سبيل المثال الفئة 
ESCryptoServiceProvider‏ 7توفر ميزات معتمدة على خوارزمية معيار تير laıllنlٽت Data Encryption Sta^dard (DES)‏ 

oithnواa.‏ الخوارزمية المطورة أصلاً بواسطة شركة ۷ 8افي منتصف1970. 


يستخدم علم التكويد المتماثل مفتاح سري مفرد ره أ۲6ءهء ماوہاء لتشفير وفك تشفير مقطع بيانات.على الرغم من أن هذه الخوارزميات وعلى 
الأغلب سريعة جداً (عند مقار تتها مع التكويد غير المتماثلرامة۲وهامراء icأمصصرءه‏ )الحاجة لتوفير مفتاح سري كامل للآخرين لمشاركة البيانات 
يمكن أن تجعلها(الييانات) ملازمة لأمن أقل.مايز ال كافي بالنسبة لعدة تطبيقات. "التشفير بمفتاح ڊ0رe^Crypi0¢ secret key‏ " 

يتضمن إطار عمل الدوت نت دعم لأربع خوارزميات تشفير متماثل: 

.معیار تشفیر البیانات(0E8‏ ) ata Encrypا1i0 S12۸227۹‏ » شفرة مقطع ۲۸۴۲ماع )عاط 56-بت مع دعم رئیسي من خلال الفئة 
ESCryptoServiceProvider‏ .هذه الخوارزمية بشكل عام آمنة.ولكن تبعاً لحجم مفتاحها الصغير (المفاتيح الأصفر أكثر سهولة في الفضح)»وهي غير 
مناسبة من أجل البيانات العالية الحساسية. 


»ەشفرة ریفست ر قم2(2 ۸٣2 )Rivest Cipher ^U b€/‏ .شفرة مقطع 56- بت مع دعم رئيسي مj‏ خJÎl‏ llذة .RC2CryptoServiceProvider‏ 


ەر يجدل /۵2€” ۸ (مشتقة من اسمي مصممیها»دیمن 026۳۸ وریجمن ۸٥زا‏ ) شفرة مقطعية ذات بت متغیر (بین 128 إلى 256 بت) )عاط 
اصhمcip‏ مع دعم رئيسي من خلال الفئة #۵وه٣ة‏ ۷ه« زا۸.ويتم تعليقها إلى خوارزمية مشابهة مسماة"'معیار تشفیر متقدم Advanced EnCrypİi0^‏ 
Standard )AS(‏ ".وهي الخوارزمية الأكثر أمناً من خوارزميات مفتاح السر المزودة بواسطة الدوت نت. 

.معيار تشفير البيانات الثلاثتي 7/١ 25S‏ .شفرة مقطعية تستخدم الخوارزمية ۳٣اه‏ وا05 المضمنة ثلاث مرات لتوليد نتيجة أكثر أمناًءمع دعم 
رئيسي من خلال الفئة eESCrypt0Ser vice Pre‏ ام .على الرغم من أنها أكثر أمناً من 0٤5‏ البسيطةءفما تزال أقل تحصيتاً ٣6۲6‏ امن 
ریجدل اھھهہزR‏ أو القياسي؟۸۴ . 

فئات "المز ود هلاهم "المتنوعة هي أدوات يجب أن يتم استخدامها مع بعضها ومع فئات التكويد لتعمل بشكل مناسب.على سبيل المتال»هذه العينة من 
الكود( المعتمدة على كود موجود في توثيق ×18 )يستخدم الفئة DESCryptoServiceProvider‏ و ال CryptoStream.كلاهما‏ أعضاء من 


: معا لتشفير وفك تشفیر مقطع نصي‎ .System.Security.Cryptography 
IMPOE ES SVSECM 
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New 


يضم هذا الكود فذئة نام رام S‏ مع mهع/ء‏ »أداة مشتركة في تطبيقات الدوت نت لنقل البيانات من حالة أو موقع لأخر.("الجداول(أو 
التجميعات) S٠4۳5‏ "هي طريقة رئيسية مستخدمة لقراءة وكتابة الملفاتءهاا؟ )الجداول ء"۳ه4٠ء8ليست‏ بأداة صعبة الاستخدام»ولكن ماتزال تبدوا 
معقد utedاconvo‏ قلیاّ. لماذا لا تتضمن الفئة DESCryptoServicePr vider‏ طرق تشفیر مرا" وفك التشفیر مر۲٥0‏ بيساطة ؟ هذا سۋؤالي»على 


الفصل الحادي عشر:الأمن Mhm76‏ 
الأقلءإني متأكد من أن لديها شيء ما يجب عمله مع حفظ الفئة "شاملة ن٠٣‏ هو "للاستخدام في بيثات بيانات متعددة.مايزال.هذا الكود كثيف ءمن المؤكد 
أنه أكثر سهولة من كتابة كود التشفير بنفسي.وهو عام بشكل كافي بحيث أستطيع مبادلة خوارزميات مفتاح سري دون تغير كبير في الكود. 


في تكويد المفتاح السريءتستطيع استخدام أي مفتاح قديم تريده لدعم عملية التشفير وفك التشفير.طالما أنك تحفظه سراء في الحقيقة محتوى المفتاح 
نفسه ليس مهم كثير آ.لايمكن قول المثل على التكويد الغير متماثل(المفتاح العام).لأن المفاتيجح المفصولة يتم استخدامها لتشفير وفك تشفير البيانات.المفاتيح 
الخاصة والعامة النوعية يجب أن يتم صنعها بشكل خاص كزوج.لاتستطبع اختيار فقط مفاتيح خاصة وعامة عشوائية وتأمل أن تعمل مع بعضها. 
المكونات المستخدمة لدعم التكويد الغير متماثل تتضمن"المولداتء۲هاة۲٠"هو‏ "والتي تصدر ٠i1‏ أز واج مفاتيج خاصة وعامة.حالما يتم التوليدهذم 
المفاتيح يمكن أن يتم استخدامها في كودك لتقنيع 5ه" البيانات الحساسة.وتبعاً لحجم المفتاح الأكبر .فمن الصعب بالنسية لكل واحد أن يدخل تعديل على 
بياناتك المشفرة. 
تشفير المفتاح العام مشهور اهاهاه ٠ببطئه»فهو‏ يأخذ دائماً يوم لكتابة كود كميات ضخمة من البيانات باستخدام المفتاح المصدري.بسبب بطء 
اءنووداءآداء التشفير الغير المتماثل.فالعديد من أنظمة أمن البيانات تستخدم جمع من تشفير مفتاح عام ومفتاح سري لحماية البيانات. التراخيص 
الأولية تحدث مع عمليات المفتاح العام»ولكن حالما تفتح قناة الأمنء البيانات الممررة بين الأتظمة التي تحصل على التشفير باستخدام طرق المفتاح 
السري الأسرع.تتضمن الدوت نت فئتي تكويد تفي برغبتك في التشفير وفك التشفير: 
.خوار زمية التوقيع الر قمي(084) ۸/90٤١”‏ 21۶^ و/S‏ /4ا/و/2 .خوارزمية صممت بواسطة الحكومة الأمريكية لاستخدام التواقبع الرقميةءمع دعم 
رئيسي مj‏ خJîl‏ llذة .DSACryptoServiceProvider‏ 
.خوارزمية 84 (موجlı Ron Rivest‏ و Shamir‏ Adi.و‏ emanاAd).خوارزمية‏ غير متماثلة الأمن أقدم مع دعم رئيسي من خلال الفثة 
.RSACryptoServiceProvider‏ 
سوف نستخدم التشفير الغير متماثل في مشروع المكتبة.ولكن ليس حتى أخر فصل.حتى ذلك الحين»لن أدخل بالكثير من التفاصيل حول أعمال التشفير 
الفير متماثل. 


على الرغم من أن خوارزميات البعثرة(خوار زميات العنونة بالكود(أو الرمون))ء٣۳١٣أ۲هواة‏ و”ا٣عه؟‏ لا تمنحك إمكانية تشفير وفك تشفير البيانات 
كما ترغب»ولكنه مفيدة في دعم الأنظمة التي تؤمن وتنحقق من محتوى البيانات.سننجز بعض البعثرة على البيانات في كود المشروع من أجل هذا 
الفصلءلدلك ابق بقظ . 
إيجاد حل خوارزمية البعثرة سهل.فهي أخذت أفضل عقول وكالة الأمن العالمية ومعهد ولاية ماسشتس للتكنولوجيا لاختراع أنظمة التشفير بمفتاح عام 
ومفتاح خاص»ولكنك تستطيع تطوير خوارزمية البعثرة بعدة دقائق فقط. إليك خوارزمية بسيطة قمت بعملها : 
EUDNIE Huneti1 on HashSOMe lez E (EVMaAl Oriolext AS SEEIMG) AS MONO‏ 
Create a hash value from some data.‏ ل 
Dim hashValue As Long = 0&‏ 
Dim counter As Long‏ 
EOE eCounmEeE — 1 TO LEN (OETGLeXE)‏ 
hashValue += Asc (Mid(origText, counter, 1))‏ 
TE (Rasha lue > EONS Max Value COE) RES‏ 
hashvValue / 2‏ 
NEE COMM ES‏ 
Return hashValue‏ 
NOL HUDNCE LO‏ 


في الكود عملت فقط على جمع قيم الآسكي لكل حرف في السلسلة الحرفية للنص.وعملت على إعادة النتتيجة.وقد عملت اختبار في الحلقة للتأكد من أنني 
لا أزيد عن %90 من قيمة الطول الأعظمي.ولا أريد تجاوز المتفير مداة۸۷ءة٣وتوليد‏ خطاأً.على الرغم من أن الدالة ×٠۲م"۸50ءةإتعمل‏ على 
تولید تمثیل مبعثر hashed representation‏ للبیانات المدخلةء لدیھا أیضاً بعض العيوبdeficieNcİS‏ : 

.من السهل جداً التخمين من قيمة التكرار 5۸ه٣فيما‏ إذا المحتوى القادم كان قصير أو طويل.المحتوى الأقصر سيولد عدد صفير»وقيم المخرجات الأكير 
تميل إلى الإشارة إلى محتوى إدخالات أكبر. 

.ليست ذات حساسية عالية لبعض أنواع تغير ات المحتوى.على سبيل المتالءإذا رتبت عدة حروف في المحتوىءمن المحتمل أن لا تؤثر على قيمة 
البعثرة.تغيير الحرف سيؤثر على القيمة ولكن إذا غيرت حرف من 4 إلى 4وحرف أخر مجاور من 7 إلى ك فإن قيمة البعثرة ستبقى نفسها ولن تتغير. 
.كلما قصر المحتوى كلما زادت فرص توليد نفس قيمة البعثرة بالنسبة لإدخالين. 

من المحتمل أنك تحتاج شيء ما أقوى.إذا كان الأمر كذلك.تتضمن الدوت نت العديد من أدوات البعثرة: 

1.بعثرة معتمدة على کود ترخیص(توتیق )الر سالة 4sh-b2sed Message Authentication Code )٢MNA°(‏ یتم حسابه باستخدام دالة بعثرة 
خوارزمية أمن البعثرة رقمS1A۸-1(1(‏ 1 Secure Hash Algorithm number‏ .یمکن جعلھا متاحة من خلال الفئة 05۳۸1٥۸۳۷1۸.وتستخدم‏ کود 
بعثرة 160 بت .لايوجد قيود ٣5‏ هاوه خاصة على طول مفتاح السر ره ٠۲ءهءالمستخدم‏ في الحساب.على الرغم من أنها مناسبة لحالات 
الخطر المنخفضةءفإن الخوارزمية 514-1عرضة للهجوم(الفزو). 
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2.کود توتیق الر سالة(N۸€°×) Message Authenticati0^ Code‏ يتم حسابه باستخدام خوار ز میة المفتاحE5sec۲6٤2D-۵eاما٣۲‏ (تم شرحھا 
سابقاً).يمكن جعلها متاحة من خلال الفئةS٤0ءام 1۸٥1‏ .مفتاح السر ۷ه ٠ءء‏ المستخدم في الحساب هو إما بطول 16 أو 24بايت. والقيمة 
المولدة بطول 8بايت. 

3.حساب البعثرة ل خوارزمية استيعاب الر سالة ر قمN×05(5)‏ 5 Message-Digest algorıthm nın ber‏ .يمكن جعلها متاحة من خلال الفئة 
.MD5CryptoServiceProvider‏ إن D5‏ ما تزال خوارزمية سرية عالية المستوی صممت من قبل رون ریفیست5ه۷اR 8٥۸‏ .ولكنها أظهرت 
احتواءها على بعض العيوب التي تجعل من أمن التشفير خطر ءا نامء ومiههعمه‏ .قيمة التكرار الناتجة هي بطول128بت. 

4.مثل الفئة 08۳4۸1٥11۸.تحسب‏ الفئة 51۸1 المدارة كعواء ١موSHA1Ma”a‏ قيمة اليعثرة باستخدام دالة البعثر 51۸-1 .مهما تکنءتم كتابتها 
باستخدام کود الدوت نت المدار مء ۵۵٥و2٣2" .N E۲‏ فقط إن ١۷۸٥08۳1۸1‏ وبعض ميزات التكويد الأخرى في الدوت نت بكل بساطة تدور حول 
(تفلف)(۸۴۱٥)‏ /۸/۶ رم2 وهام الأقدمومكتيات الربط الديناميكي للاوت نت السابقة اا٥‏ ۲٤..-ام.SH۸1‏ المدارة تستخدم کود بعثرة 

0 بت. 

5.فثات ثلاث أخرى:51۸256 المدارة. 51۸384المدارةء 1۸512١5المدارة‏ »مشابهة لفئة 51۸1 المدارة.ولكن تستخدم أكواد بعثرة 256بت 
بت.و512بت علی الترتیب. 

کل من هذه الخوار زمیات تستخدم مفتاح السر الذي یجب أن یتم تضمینه کل مرة یتم تولید البعثرة على نفس المجموعة من البيانات المدخلة.طالما أن 
البيانات المدخلة لم تتغفير »ومفتاح السر هو نفسه.ءفقيمة التكر ار الناتج ستبقى غير متغيرة.تصميمياءحتى أصغر تغير في البيانات المدخلة يولد تفيرات 
رئيسية في قيمة البعثرة المخرجة. 


دوج الففك فن هزات الأ من المافة والتى لن أناقغها ها بالمقكعل ولك سعد على الاق أن اش إلا 


يتضمن كائن الفيجوال بيسك #۲ءل.ر» العديد من ميزات الترخيص(التوثيق١٥ااةء‏ )١٣اه‏ ) والتي يمكن أن تساعد على تصمیم كود تمكين 
الأمن.عضو واحد مفيد هو خاصية "الاسم ۳ه" ".والتي تزود باسم المستخدم المرخص حالياً.تخيرك الطريقة ٥ا٥۱۸۸ء!‏ فيما إذا المستخدم الفعال یتم 
تضمينه .فيما يدعى مجموعة أمن المدراءupتrو the Administrators security‏ .من أجل تطبیقات نماذج ویندوز.ستشیر أعضاء ۲٥ءل.My‏ بشکل 
نموذجي إلى تسجيل دخول مستخدم ويندوز. مهما يكن .تستطيع استخدام أنظمة توثيق ء”٣#اءرء‏ ١0ناهءنا٣‏ 6٣اه‏ أخرى والتي تليي احتياجات 
التطوير الخاصة بك.تتضمن الخيارات ١‏ ٥نام0‏ استخدام الانترنت المعتمد على نظام "معرف وiıدjg‏ ايف" Internet-based “Windows Live‏ 
”ا من ميكر وسوفت»وأنظمة توثيق تانوية مشار كة أخر ىء" هاءرء 0٣‏ هعنام third-party auth‏ .أو نظام إدارة المستخدم المخصص التصمیم من 


إنه لمن المميز فمع كل هذه الأدوات المتقدمة .ما يزال المستخدمين يمضون الكثير من الوقت في البناء وتفسير البيانات النصية.لحسن الحظءتتضمن 
الدوت نت وفرة من أدوات مفيدة لمعالجة النصوص .ولكن لسوء الحظهي ليست أمنة كثير .من المحتمل أنك تتذكر أن نصوص الدوت نت ثابتة 
eاinmutabء‏ حالما يتم إنشاءهاءفهي لن تتفير.أخير آءسيتم تدمي رها بواسطة معالجة مجمع النفايات.ولكن حتى ذلك الحين»فإنها تستقر في الذاكرة.منتظرة 
أن يتم عمل مسح بواسطة كود المصمم من قبل هكر ما.بشكل داخليءالبيانات النصية يتم تخزينها كنصوص سهلةءلذلك إذا ما استطاع شخص ما 
الحصول على الذاكرةءيستطيع نسخ المحتوى لأهداف شريرة كuها٣‏ هه" . 

تيح لك الفئة و” 5ه اءمS.راcuهS.صءstركتخزين‏ النصوص والحصول عليها مره أخرى.ولكن داخلياًءمحتوى النص يتم تشفير ه.إذا ما حصل 
شخص ما على محتوى داخلي لحالة فئةءسيبدو مثل الثرثرة٣ءا‏ 6ططو . 


هذا الفصل سبيين ميزات متمحورة حول مواضيع الأمن التالية والمضافة لمشروع المكتية: 

. فورم تسجيل الدخول" ”اوها ".والتي توثق(تثيت صحة)أمناء المكتية. و المستخدمين الإداريين الآخرين. 
.نماذج مجموعة الأمن وإدارة المستخدم. 

.دالة onناuncاتعمل‏ على تشفير كلمة المرور المزودة من قبل |لمږتخذpasswordp user-supplied‏ . 
.تفعيل بعض ميز ات التطبيق والتي تعتمد على توتيق(تصديق 6,١ ٤ ءهاا0٥ ١‏ ٣اه‏ )المستخدم. 


بما أن جميع بيانات المكتية يتم تخزينها في قاعدة بیانات سکول سرفر.فقد استخدمنا سابقاً إما ویندوز Ws‏ ٥ہ‏ أو امن مخدم سکول S۵1 S6۷6۲‏ 
cuit‏ (أمن سكول سرفر) لتقيد tء‏ ٣٤ء٠‏ الوصول إلى البيانات نفسها.ولكن حالما نتصل بقاعدة البياناتء سنستخدم نظام تصديق (توثيق)مخصص 
لتمكين وعدم تمكين ميزات في التطبيق.فهو موجود هناك بحيث نضع بعض میزات تشفیر دوت نت قید الاستخدام. 
قبل إضافة الكود المهمءنحتاج لاضافة بعض المتغير ات العامة والتي تدعم الأمن على كامل التطبيق.جميع هذه العناصر العامة تظهر في الملف 
Gera.‏ . ضمن كود الوحدة البرمجية . 
Public LoggedInUserID As Integer‏ 
Public LoggedInUserName As String‏ 
Public LoggedInGroupID As Integer‏ 


Mhm76 الفصل الحادي عشر:الأمن‎ 
PuUbDliG SECUEIEVEEOE1 le (MaxLIDralrYSeECUE1 EY) AS Boolean 
ه۲طناسابقاء فهو جزء هام من نظام الامن.وعناصره تطابق ما یتواجد في جدول راا۷ا۸ في‎ yS على الرغم من أننا عملنا على إضافة العداد را‎ 
اه5 والتي أضفناها الآن إلى الكود.‎ ۴٣ قاعدة بيانات المكتبة.كل قيمة للعداد توافق عنصر في المصفوفة اناه‎ 
قيم الأمن‎ 
Public Enum LibrarySecurity As Integer 
ManageAuthors = 1 
ManageAuthorTypes = 2 
ManageCopyStatus = 
ManageMediaTypes 
ManageSeries = 5 
ManageGroups = 6 
Manageltems = 7 
ManagePatrons = 8 
ManagePublishers = 9 
ManageValues = 10 
ManageUsers = 11 
ProcessFees = 12 
ManageLlLocations = 13 
CheckOutItems = 14 
CheckInItems = 15 
AdminFeatures = 16 
DailyProcessing = 17 
RunReports = 18 
PatronOverride = 19 
ManageBarcodeTemplates = 20 
ManageHolidays = 21 
ManagePatronGroups = 22 
ViewAdminPatronMessages = 23 
End Enum 
Public Const MaxLibrarySecurity As LibrarySecurity =LibrarySecurity.ViewAdminPatronMessages 


جميع المتغير ات العامة الجديدة المضافة تخزن معلومات مطابقة للمدير ۲هاه٣ءا‏ ا٣‏ هه الفعال.عندما يكون زبون هو المستخدم الفعاليضع البرنامج 
هذه القيم لإعداداتها الافتر اضية.بما أن هذا يجب عمله عندما بيدا البر نامج للمرة الأولی.سنضیف روتین ۵٣‏ اءر؟هzااهناا١|‏ يتم استدعاءه عند 
البدء.ويظهر هذا الروتين أيضاً في الوحدة البرمجية اة۲٠٣ه6.‏ 


e 
کک‎ 


PUDIIE SUS InIEIa lI ZeSVSEEM () 

E TN E E a 1 

Dim counter As Integer 

الاه حم ان دت ا 

LoggedInUserlD = =1 

LoggedInUserName = "" 

LoggedInGroupID = =1 

For counter = 1 To MaxLibrarySecurity 
SecurityProfile (counter) = False 
Next counter 

EO Sub 


(لدی مصفوفة ٥ان‏ ہ٣۴‏ رااuه5بنود‏ تتراوح من 0إلى Max ibrary Security‏ ولكن الحلقة عند نهاية هذا الكود تبدأ من العنصر1.ءلاأن جدول رإاا۷اا۸ 
يبدأ العد من 1 .فقررت تجاوز العنصر0).يتم استدعاء الطريقة e۳اءرS٥zاا‏ نا٢۱‏ من الحدث MyApplication_Startup‏ في ملف 
/ica tion Event. b‏ م . تماما قبل تأسيس الاتصال إلى قاعدة البيانات.لذلك دعنا نضيف الكود الآن. 


/عمل تمهيد عام 
InitializeSystem ()‏ 
كل مرة يحاول مدير استخدام النظام»وكل مرة يسجل خروج ويعود البرنامج إلى نمط الزبون(العميل).فإن جميع المتفير ات العامة ذات الصلة يجب أن 
يتم إعادة وضعها.وهذا يتم عمله في الطريقةاءSرااuءه5SءءهعهءمهR‏ .أضف هذه الطريقة إلى الوحدة البرمجية ا۴۲2٣ه6.‏ 
Public Sub ReprocessSecuritySet ()‏ 
: إأعااة التجميل فق حورعة الاين اللمستخدم احاال. 
ر لا ا لكل الا ال الاح رل مت و ا ن اا 
Dim counter As Integer‏ 
Dim sqlText As String‏ 
Dim dbinfo As SqlClient.SqlDataReader = Nothing‏ 
: اا د ا و 
For counter = 1 To MaxLibrarySecurity‏ 
SecurityProfile (counter) = False‏ 
Nez GOUNECE‏ 
E E E CO Ta 1‏ و ا 
Tf (LogqgedInUserlD = =1) Or (LogqgedInGrouplD = =1) Then Return‏ 
HEY‏ 


الفصل الحادي عشر:الأمن Mhm76‏ 
١‏ التجفل فق عاضر الان اا اداع 
SqIText > "SELECT AelivilvVID EROM GrOupACtIVIEyY WHERE GroupID <F" ¢ TOoOIeQAINGrOUPLD‏ 
dbInfo = CreateReader (sqlText)‏ 
Do While (dbInfo.Read)‏ 
SECU EVE OE LE KC IRE (OBIDEONAEEI VA EVID) ST‏ 
Loop‏ 
dbInfo.Close ()‏ 
Catch ex As Exception‏ 
N O A N‏ 
GeneralError ("ReprocessSecuritySet", ex)‏ 
TE (OBINEO ISN NOERIARS) Caen GQBINEO CIOS)‏ 
EE N EEN N EEN N GOL, N EES E‏ 
LoggedInUserlD = =1‏ 
LoggedInGroupID = -1‏ 
ReprocessSecuritySet ()‏ 
BRANLY‏ 
dbInfo = Nothing‏ 
el‏ 
End Sub‏ 
يستخدم هذا الروتين كود تم بناءه في الفصل العاشر وفصول سابقة.فعندما يكتشف هذا الروتين مستخدم موثوق(مصرح به)(أي المتفير 
Dاserلl0ggedın)فإنه‏ ينشئ الكائن #۲كة٥1۸د2اوS‏ مع ميزات امن المسموحة للمستخدم»ويخزن تلك الاإعدادات في المصفوفة 
SecurityProfile.<الما‏ یتم تحمیلهافيمتل أي عنصر للمصفوفة عندما یکون صحیح ۵د۲۲ ميزة التطبیق أن المدیر 0۲ ھİs†rہİ¡ N‏ 0مصرح به کي 
يستخدم التطبيق.ساناقش جدول راا۷أ۸مده6۲بعد قليل في هذا الفصل. 
إذا ما حدث خطأ قاعدة بيانات خلال المعالجة.يعمل الكود على إعادة وضع كل شيء إلى نمط العميلوعمل استدعاء دوري ٠۷ا5 J/e٤u‏ 
ReprocessSecuritySetلتنظيف‏ المصفوفةeاiگە۴r Security‏ .(یحصل التکر ار المستمر ١٥ایاu‌مR‏ عندما یستدعي روتین نفسه بشکل مباشر أو غير 


مباشر.) 


سأستخدم واحدة من طرق خلط(بعثرة) الدوت نت لتشفير كلمة المرور المزودة من قبل المدير قبل تخزينها في قاعدة البيانات.واحد من جداول قاعدة 
بيانات المكتية.جدول ٠4۳١۲ءءلاءيخزن‏ قالب #ان۴ه۲مالأمن الأساسي لكل مكتبي أو مستخدم إداري أخر»ومن ضمنها كلمات المرور.بما أن أياً كان 
يستطبع الدخول إلى قاعدة البيانات سنكون قادرين على رؤية كلمات المرور المخزنة في هذا الجدول.فسنعمل على تشفيرها لجعلها أقل جدباً.( من أجل 
الزبائن الذين يستخدمون البرنامج ببساطة.فليس من الواجب عليهم الوصول مباشرة إلى قاعدة البيانات بعيداً عن التطبيقءولكنك لاتعلم هؤلاء الزبائن 
اللعوبين). 

لحفظ الأشياء آمنة.فسنشوش(نمزج هاا١٠هءءء‏ )كلمة المرور المدخلة من قبل المستخدم»واستخدامها لتوليد قيمة خلط(بعثرة)وتخزين قيم البعثرة في حقل 
كلمة المرور ١0۲سءءهملقاعدة‏ البيانات من أجل المستخدم.فيما بعد عندما يريد مستخدم مدير الحصول على إمكانية الوصول إلى الميزات 
المحسنةءفإن البرنامج سيحول مره أخرى كلمة المرور المدخلة في قيمة البعثرة(الخلط)ءويقارن تلك القيمة بكلمة المرور المخلوطة(المشفرة) في السجل. 
كل دالة بعثر ة(خلط|للدوت نت تعتمد على كود سري.بما أن مشروع المكتبة سيعمل فقط تشفير غير مباشر»ولن يسأل أي برنامج أخر أبداً لإعادة تشفير 
كلمة المرورءفإننا سنستخدم فقط اسم تسجيل الدخول للمستخدم كمفتاح "سر ي†٠۲٥هء‏ ".قررت استخدام فئة البعثرة 1۷1۸٤٥5۳۸1‏ »على الأغلب من أجل 
قدرتها على قبول مفتاح متغير الحجمهzاءهاطها۲ج‏ .على الرغم من أنها مقررة لأن تحتوي قضايا الأمنءفإن هذا لن يكون مشكلة بالنسبة للطريقة التي 
سنستخدمها بها.أعنيءإذا ما حاول أحدما الدخول لقاعدة البيانات فعلياً لفك تشفير كلمات المرور المخزنة في جدول ١4۳٠‏ ۲ءءلاءفسيكون لهذه الفئة 
إمكانية وصول كاملة لكل شيء في نظام المكتية سابقا. 

بالطيع.يتطلب كود التشفير مرجع إلى فضاء الأسماءر۸مةrوەامSecurity.Cry. system‏ .وسنحتاج أيضاً مرجع إلى ۲×٠٣.٣ءاءركمن‏ أجل بعض الدعم 
للكود.أضف عيارات ا۲مم٣!‏ ذات الصلة إلى أعلى ملف كود طe/2/.۷” 6e‏ . 


MOOSE ES SVS lex E 
IMPOE ES SVSEEeM. SeCUEI EY. CEVPEOIE ADRY 


تحدث البعثر ة(التشويش) الحقيقي لكلمة المر ور في الر وتينك۲هسءءه1۴مرإء"ع .لذلك اعمل على إضافته إلى كود الوحدة البرمجية اة۴۲٣ه6.‏ 
PUBDlIE EUREEIOR ERC VPDEEA SSWOEdA (BYVaN Too nID AS SEIR, BVVal PpaSSWOrAUOexXE AS SEIN) AS SEEING‏ 
إدخال اسم المستخدم وكلمة المرورءتشفير كلمة المرور بحجيث تصبح من صعب فك تشفيرها. 
٠ايوجد‏ حد لطول كلمة المرور بما اتهاستصبح مشفرةباأي طريقة. 

Dim hashingFunction As HMACSHALIL 

Dim secretKey () As Byte 

Dim hashValue () As Byte 

Dim counter As Integer 

Dim Eesult AS Sizing =‏ 
مر اح ال وا رة لق ااه اة ن ال الاترار. 
"ومن ثم حشره في مصفوفة بايت. 

secretKey = (New UnicodeEncoding) .GetBytes (UCase (loginID) ) 
إنشاء مكونات خلط(تشفبر)تستخدم 514-1 المدار‎ ١ 

hashingFunction = New HMACSHA1 (secretKey, True) 


الفصل الحادي عشر:الأمن Mhm76‏ 
اا ا 0 ا و اح کا ن ا 
hashValue = hashingFunction.ComputeHash ( (New UnicodeEncoding) .GetBytes (passwordText) )‏ 
قيمة البعثرة جاهزة»ولكنني أحب الأشياء في نص بسيطء 
E E EC‏ ل د کت ری کا وو یع :عا وها 
Or CEoSuUnNEeE = O TO MaSNVal Ue. LeNIEN 2‏ 
result &= Hex (hashValue (counter) )‏ 
NEE COMME‏ 
Al E CT N OT‏ > 
Return Left (result, 20)‏ 
EDGd ENE ENON‏ 
الطرق الرئيسية للتفاعل مع مزودات الاأمن ك٣#لا۷هآم‏ رااuءهء‏ في الدوت نت هي إما بواسطة مصفوفة بايت أو تجميع (ستريم).آثرت استخدام طريقة 
مصفوفة بايت. بتحويل القيم النصية القادمة من خلال الطريقة ءءار۲8ء6للكانن وہiلەء"‏ ع ههءاہلا. حالما يتم تخزين مصفوفة بايت.قمت بتمرير معرف 
الدخول 0| ”iوه‌اوكلمة‏ المرور ١0۲سءءهمكمعاملات‏ نسبية كا”عمص ىو هإلى ميزات الفئة .41M۸°٥C8۳4۸1‏ 
على الرغم من أنني أستطبع تخزين مخرجات الطريقة ام١٠‏ مباشرةٌ في حقل قاعدة البيانات.قررت تحويل النتيجة إلى رموز الأسكي 
1I‏ القابلة للقراءة لذلك فإن تلك الأشياء لن تبدو مقلقة عند إصدار ل#دءءعبارات سكول على جدول ٠#۲۸۳ءل.التحويل‏ الذي قمت به أساسي 
asicط:تحويل‏ كل بايت هارطإلى مكافئه الست عشري القابل للطباعة ٤ءامui۷وء‏ اaصhexadeci‏ eاrintabم‏ باستخدام دالة الفيجوال بيسك×ه1 . 
ومن ثم سلسلة فقط التتائج مع بعضها البعض.حقل كلمة المرور لجدول ١۳٠۲۸هءل‏ يحفظ فقط 20 حرف.لذلك قطعت(بترت؟أه مهء )أي شيء 
أطول.ومن أجل التأكد فقط أن هذه الخوارزمية تولد مخرجات معقولة »استدعيت ١0۲س55ة۴امرا‏ همع عدة مخرجات مختلفة. 


MsgBox ("Alice/none: " & EncryptPassword("Alice", "") & vbCrLf & "Alice/password: " & EncryptPassword("Alice", 
"password") & vbCrLf & "Bob/none: " & EncryptPassword("Bob", "") & vbCrLf & "Bob/password: " & 


EREEVEEESSSWMOEANL ESE TG BESSON 
يولد الكود السابق الرسالة المبينة في الشكل التالي:‎ 


LIBRARY 


Alice“none: BBFUFLZA1 4A4 FIFLUA3F 40 
ûlizepazsword: 4ù4E LEL 4L-BSD SSBB DUBE 
Bob#none: fF5441 20E 34B SFB 48LC32 
BobF*pazsword: Z744BEFO4FZ33E4UB 3E 


موان 


تعرف الجداول UserName‏ و GroupName‏ و Activity‏ eroupفي‏ قاعدة البيانات أشكال الأمن لكل مستخدم إداري.كل مستخدم(سجل في جدول 

ser Name‏ )هو جزء من مجموعة أمن(سجل ٠۸2۳مدهإ6).كل‏ مجموعة تتضمن إمكانية وصول إلى صفر 2٥۲0١‏ أو عدد أكبر لميزات التطبيق 
المحسنة»يعرف الجدول راا۷تاء۸مسهءت أي الميزات التي تتطابق مع كل سجل مجموعة أمن من جدول ۸2۳e‏ مuهءG‏ . 

لإدارة هذه الجداولءنحتاج إلى إضافة نماذج خاصية ٤٥۲٠١5‏ رأ#مه١م‏ والتي تحدث حقول سجل مفرد لقاعدة البيانات.لقد كتبنا سابقاً بعض الكود 
الخلفي منذ فترة قليلة. عرف الفصل الثامن ملفط» ٥0٥١6/۶٠٠١.‏ ١ء82‏ .قالب من أجل النماذج والتي تحدث سجلات مفردة لقاعدة البيانات.ونفس 
الفصل قدم ملفط» .ئه/0ء٠0/۲/۴ع1ء//‏ .الفورم الرئيسي الذي يعرض قائمة بسجلات قاعدة البيانات المسبقة التعريف.محرر سجلنا من أجل كل 
المستخدمين ك#۲5ءاومجموعات الأمن كمناه۲و رأناناءهء سيستخدم ميز ات في هذين النموذجين الموجودين. 

عندما صممنا الكود من أجلط ٠٠”.‏ 006٥٥ء8‏ في الفصل التثامن»كان هدفي توضيح لك ميز ات الفئة ٣ہ Must Override Mus!‏ المضمنة في 
الفيجوال بيسك.وهي ميزات مفيدة نوعاً ما.لسوء الحظ إنهما فقط لايمتزجان بشكل جيد مع عناصر واجهة المستخدم» وإليك لماذا:تعمل الفيجوال أستوديو 
فعلياً على إنشاء حالات(نسخ5هء"هاء١|‏ ) من نموذجك وقت التصميم ٠٣ا‏ ”واه بحيث تستطبع التفاعل معها داخل المحرر.إذا كنت تريد أن تسير 
الكود المصدري»صرح عن أداة صندوق نص×180×٠٠‏ .فستجد كود خاص يتعامل مع تقدمة وقت التصميم للاداة.هل هو هام؟نعم»مرن؟ نعم»متالي في كل 
الحالات؟1. 

المشكلة والمشكلة هي وضعه بشكل معتدل»هل لأن فيجوال بيسك لا تستطيع إنشاء حالة فئة معرفة ک(یجب أن تشتق٤ن us! ٣٣۲‏ )وهذا لأنك يجب أن 
ترثها من خلال فئة أخرى أولاً قبل أن تنشئ حالات.ماذا يعني هذا لك؟هذا يعني إذا حاولت تصميم نموذج يشتق من قالب نموذج"يجب وراثته 
nherاtاus".‏ فإن الفيجوال بيسك لن تجلب حصة واجهة المستخدم للفورم من أجل تحريرك الخاص.وما يزال بإمكانك الوصول إلى الكود المصدري 
للفورم»وإذا ما كانت هذه هي الطريقة التي تر يد تصميم نموذج مشتق |١6۲١ ٤٥۲١‏ .فهذا جميل.ولكننا نبحث عن البساطة في البرمجةءلذلك سوف 
نستخدم بالتأكيد أدوات الفيجوال أستوديو الخاصة بالفورم لتحرير نماذجنا المرئية. 

زبدة الكلام أن علينا تغير ملفط۷ ٥0٥26۶٠/7١.‏ ءء842 »وإزالة الكلمات المحجوزة امطnاtاMusوMust0verride‏ »وعمل التعديلات المناسية الأخرى. 
لقد عملت على تعديل التغيرات سابقا. 


الفصل الحادي عشر:الأمن Mhm76‏ 
هذا جزء من حقيقة البرمجة في الأنظمة المعقدة مثل الفيجوال أستوديو.في بعض الأحيان»حتى بعد أن تعمل جميع أبحاثك وتشبك بحذر ميزات التطبيق 
والتر اكيب»إنك تشفل ضمن مصمم ما أو مترجم سلوك معين بحيث يجبرك على صنع بعض التغيير .حالما تتعلم تجنب المشاكل الرئيسيةءستجد أن هذا 


لذلك.لنرجع إلى محرر سجل 2۳٠‏ ۸مںهء6.لم أعمل على إضافته إلى المشروع بعد.لذلك لنعمل على إضافته الآن.لأنه سيرث من نموذج أخر في 
المشروع»علينا أن نسمح للفيجوال أستوديو استنساخ النموذج القاعدي بتر جمة التطبيق أولً.وهذا يتم عمله بسهولة من خلال بناء ١ا8‏ > > أمر قائمة 
بنcl‏ |lلıiSaةaryٽLibr Build‏ . 
لإنشاء فورم ٤٥۲۳‏ جدیداختر مشروع ۲ هزه۴۲ > > أمر القائمة أضف نموذج ویندوز ۴٥۲۳‏ ۷W٥هہW1‏ ۸۵۵ .عندما يظهر بند ویندوز الجدید, اختر 
Forms‏ indowsمن‏ قائمة التصنيفاتءهiاه‏ وها . المتبوعة بواسطة "۴0 nherite4ا|‏ من قائمة القوالبءهاهام ۲٠٣”‏ .أدخل في حقل الاسم 
Group Name. vb‏ ومن ثم انقر الزر ه۸۵ .عند يظهر نموذج ناخب الور اثة ٤٥۲٣‏ ۴)۵۲ مء" هاامطما (شاهد الشكل التالي). أختر من القائمة 
.BaseCodeForm‏ وانقر موافق0K‏ .یظهر النموذج ۸4۳۵مںه6الجدید:ولکن بیدو علی نحو رائع مثل الفورم ۴0۲۳ .8B a۵٥0۵‏ 

ert Picker o E . 2سا‎ 
Specify the component to inherit From: 


Lampanent Name Namespace Larcakian 


LIBRARY Filearningicomputer{ PROGRAMING LANGUIGE IYE NE 
LIEBEARY Fiîlearningicomputer{PEOARAMING LANGLUIGE TYE . NE) 
LIBEARY Filearningicomputer{ PROGRAMING LANGUIGEIYE NE 
MainForrn LIBEAR'Y Filearningicomputer{PROSRAMIMS LANSUISEIYE NE 
Splash LIBEAR'Y Fi\learningicomputer{ PROGRAMING LANSUISEIYE. NE 


New component name: aroupNarmê 


أضف أداتي عنوان(لصاقة1٠5ها‏ )» وأداتي صندوق نص×٥۲8×٠۲‏ »وأداتي زر ١٥ا8‏ .وأداة صندوق قائمة اختبار ×٥۲8ءiاكه ٤۸٠٤)‏ من صندوق 
الأدوات. وضع خاصياتها باستخدام الإعدادات (راجع المشروع المخصص لهذا الفصل). 
ولا تنسى تعديل ترتيب التنقل(مفتاح )للأدوات على الفورم.لنعمل على إضافة الكود كله دفعة واحدة. أضف الكود التالي لجسم الكود المصدري للفئة: 


Private ActivelD As Integer 
Private StartingOver As Boolean 


Public Overrides Function CanUserAdd() As Boolean 
EL am a N A O EL 

Return SecurityProfile (LibrarySecurity.ManageGroups) 

End EUnNCEIOR 


Public Overrides Function CanUserDelete() As Boolean 
E a N E O CC SL 

Return SecurityProfile (LibrarySecurity.ManageGroups) 

O RCE OM 


a 
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Public Overrides Function EditRecord (ByVal recordID As Integer) As Integer 
SE ES EI | 

AEE ivwel Dl > EECOEIID 

PrepareFormEields () 

Me. ShowDialog () 

If (Me.DialogResult = Windows.Forms.DialogResult.OK) Then _ 
Return ActivelD Else Return -1 


Public Overrides Function FormatRecordName (ByVal recordID As Integer) As String 
Dal Sele e A CEA 
On Error GoTo ErrorHandler 
EL EO O 
sqlText = "SELECT Ful1Name FROM GroupName WHERE ID = " & recordID 
Return CStr (ExecuteSQLReturn (sqlText) ) 
ErrorHandler: 
GeneralError ("GroupName . FormatRecordName", Err.GetException () ) 
Return Errol" 
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O EES EEO CSE E EO LS SEG 
ا جاع ا ا‎ 
E Groups" 


ion TT As Boolean 
1 ا ا د ا اه ر‎ 
Dim TT As string 
Dim EID AS IO اک ج ت‎ 
e GoTo ErrorHandler 
ا و ا ا ات‎ 
Me. = Windows.Forms.Cursors.WaitCursor 
TransactionBegin () 


N 
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Return True 


Hand 
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Private Sub RecordFul1Name Enter (ByVal sender As Object, ByVal e As System.EventArgs) Handles 
RecordEFul lIName. Enter 


و غلم ايل اال 
RecordFul1lName. SelectAll ()‏ 
ERAG SUBS‏ 


End Class 
لقاعدة البيانات المعروض,أو-1 عند تحرير سجل جديد.العلامة‎ Gءهuم‎ 2۳e رقم 0| لسجل‎ Active تتضمن الفئة عضوين خاصين.يحفظ‎ 
مده المدخلة سابقا.للسماح لهذه الفورم‎ ١4۳٠ أكثر أهمية نوعاً ما.تذكر أننا نستخدم نموذج ملخص متشارك لعرض جميع سجلات‎ Statin 0و‎ ver 
مه6 في هذه الحالة)إلى‎ ١2٣٠٠ من العمل مع محررات السجلات المختلفة.نمرر حالة من نموذج التفاصيل(۷6.‎ » List عdiاRععه٣لء.۷طةلماشلا‎ 


نموذج الملخص: 

ListEditRecordsvb.ManageRecords (New LIBRARY.GroupName) 
بعد مرةءکل مرة يريد المستخدم إضافة آو تحديتث سجل‎ Î yeGroupName ضمن کود النموذجطvیك ء۲٤٥۳۵18 stذا بیتم استخدام حالة من‎ 
قاغدة الانات ةاون 5.66 خحت المشتخم سكل وأخد ومن تم خاول تخذيث واج أخر فان المتيقي من السجل الأول قى موجوة في قول‎ 
نموذج التفاصيل.وهكذاءسيكون علينا تنظيفها كل مرة نضيف أو نحدث سجل مختلف.يساغد الدليل ١0۷6و:١هابهذة العملية وذلك باعادة وضع التركيز‎ 
. جذومنلل4هان۷هأ#١ إلى حقل نموذج التفاصيل الأول في حدث‎ 


الطريقة الخاصة كلا٠ ٠١۳۴‏ ۴٠٣همهإ۴تعمل‏ التنظيف الحقيقي وتخزن البيانات مع كل استدعاء لتحديث أو إضافة جديدة.من أجل السجلات الجديدة. من 
البساطة تنظيف كل البيانات المدخلة على الفورم.عند تحديث سجل موجود.فإنه يستخلص البيانات ذات الصلة من قاعدة البيانات»ويخزن القيم المحفوظة 
في حقول متنوع على الفورم.العبارات التالية تعرض اسم المجموعة المخزنة في حقل ٥اا ۸۵٥٥۲۵۴‏ .أو ادا صندوق نص×۲۵×۲80 . 


SE ET SKE O A ET ONT 
sqlText = "SELECT FullName FROM GroupName WHERE ID = " & ActivelID 
RecordFullName.Text = CStr (ExecuteSQLReturn (sqlText) ) 
ةقيرطلا.8Bهء۵٤ه١ء‎ ۴٠۲۳ معظم الروتينات في نموذج م2۳ مه توفر إعادة قيادة كع ل۲۲ ۷#هبسيطة من أجل الاعضاء القاعدية لفئة‎ 

an لser Ad‏ والتي تعود بيساطة بخطأاً ها۴ في الفئة القاعدية.تتضمن منطق حقيقي في الفئة المشتقة.إنها تستخدم المصفوفة هااه ٣۴ران‏ uء‏ ه5 التي 

أضفناها سابقاً لتحديد أي مستخدم حالي مسموح له إضافة سجلات مجموعةsلc0۲ group re‏ . 

Public Overrides Function CanUserAdd() As Boolean 

4 اجار ااال ن ال اتعافهة اسل ال اة 
Return SecurityProfile (LibrarySecurity.ManageGroups)‏ 

dl UNECE TOM 
ll. SearchForRecordgUsesSearch قJقرطلl‎ lعlم‎ Base CodeForm ءlځعe|‎ gعıeجJoverridمs‎ öدايق إذا نظرت إلى الكود المضاف»ءستجد إعادة‎ 
المشتقة تقبل الفعل الافتراضي لهذين العضوين.‎ 
«DeleteRecord و‎ EditRecord g«AddRecord öدژق يضيف المستخدمءل0ه .يحدثكءااك١ه »ويحذف كهاءاملسجلات اسم مجموعة من خلال إعادة‎ 
.EditRecord على الترتيب.لكل استدعاء من قبل الكود في فور مءلrهءء 1۸ع اءLi .إليك كود‎ 
Public Overrides Function EditRecord (ByVal recordID As Integer) As Integer 
تحديث سجل موجود.‎ 
ActivelD = recordID 
PrepareFormFields () 
Me. ShowDialog () 
1E (MS DESO 3 MIMI. ROS Di ALOE EO TIS | 
Return ActivelD Else Return -1 
e C2 
بعد تخزين معرف | السجل للتحديث في الحقل الخاص0٥۱ء۷ناء۸ .يحمل الكود البيانات من خلال الطريقةءلاه2۲۵۴۵۲۳۴م٠٣۴ . ويحث المستخدم‎ 
على تحديث السجل باستدعاءوه‌اها0سه 0۵.5۸ .ينتظر الفورم حتى يضع كود ما أو أداة خاصية الفورم†ااءه۸# وه اهاد .وهذا يتم عمله في الحدث‎ 
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الفصل الحادي عشر:الأمن Mhm76‏ 
Clik‏ _Act0K.وأيضاً‏ من خلال الخاصية انه #وه!اهiصطللز‏ ر ا#»٣‏ 2٤۲ء۸‏ .والتي ستعمل الفيجوال أستوديو على إسناده إلى الفورم بشكل آلي عندما 
ينقر المستخدم الز راActCance‏ . 

إن الروتین 0۲۵٥۸۵۵۸یشبه‏ کثیرآً الروتین۲۵٥٥ E۵1۸۲‏ »ولکنه یسند -1 إلى العضو ۸۷۵۱0 لیشیر لسجل جدید.الروتین ۵۲۵٥٥۵۸٥ا0e‏ آکثر 
تعقيداء ويستخدم بعض كود قاعدة البيانات الذي كتبناه في الفصل السابق(ر اجع كود lلدöl (DeleteRecord‏ 

بعد تأكيد الحذف من قبل المستخدم»يحدد تفحص سريع فيما إذا المجموعة مه۲ وما تزال قيد الاستخدام في مكان في جدول٥‏ ٣۵۸4ل‏ .إذا كان كل 
شيء تم مراجعته على مار امءیتم حذف السجل باستخدام عبارة سکول 1۴۲۴٤0.بما‏ أننا نحتاج إلى حذف البيانات في جدولين»فقد ضمنته كله في مداولة 
transaction.إذا‏ ما حدث خطأًءفإن معالج الخطأً عند نهاية الروتين سيتراجع عن المداولة .TransactionRollback Jڵlخ ja‏ 


عندما يتم عمل تغيرات من قبل المستخدم إلى السجل.فإن النقر على الزر "موافق 0۸ "يدفع البيانات المخرجة من قاعدة البيانات إليها مرةٌ أخرى. 
یتحقق معالج الحدث »ءا٥_۲0۸٥۸‏ من البيانات»ويحفظها. 


تعمل الطريقة ة2 ٣۳١٠۴ءاةلااة۷بعض‏ الاختبار ات اليسيطة للتحقق من البيانات»مثل الطلب من المستخدم إدخال اسم مجموعة الأمن أا uعمء‏ 
name‏ مroupو.وهذا‏ ممیز.إذا ما بدا کل شيء علی مایرام»يبني الروتين a٥۲۳٠۴ء۷ه5عبارات‏ سكول التي تحفظ البيانات(راجع كود الدالة 
ve۴0rmataهsS).تأكد‏ من مراجعة الروتينات الأخرى في نموذجه2۳١مدهء‏ .فهي موجودة لدعم وتحسين خبرة المستخدم. 


نحتاج أيضاً إلى فورم لادارة سجلات جدوله" 4١هل‏ .بما أن كود تلك الفورم بشكل عام يتبع ما رأيناه سابقاً في نموذجه٣ة١مںهء6‏ .فلن أثقل عليك 
بالتفاصيل.لقد عملت على إضافة 7٥.۷‏ ۸N2/ءءل‏ لمشروعك.ولكن لمنع الأخطاء في كودك بينما تكون في وسط التطوير.فقد عملت على تعطيله. 
ولتمكينه» اختر هذا الملف في نافذة مستکشف الحلول۲۲٥٣ہام×E‏ ۸٥iاں‌اهS‏ .ومن تم في نافذة الخصائص؟ءااامم٥٣۴‏ .غير خاصیة ۸٥ااAc‏ dاBui‏ من 
.Compile J!None‏ 

الكود الوحيد المهم في هذه الفورم والذي هو مختلف نوعاً ما عن فورم ٠۳٣ة١مهإ6‏ هو معالجة كلمة المرورك۲هسءءهم .ولاحفاظ على الأشياء سرية 
قدر الإمكان.فلن أحمل فعلياً كلمة المرور المحفوظة ضمن حقل كلمة المرور على الفورم. ولن أعمل أية طريقة جيدة منذ أن عملت على تخزين 
نسخة(إصدار) الخلط هم۷ ١هطءهم‏ في قاعدة البيانات.بما أنني استخدم معرف تسجيل الدخول ۱0 اوها للمستخدم كمفتاح سري عند تشفير كلمة 
المرور»يجب علي أن أعيد توليد كلمة المرور ١0۲سءءهمولو‏ غير المستخدم معرف تسجيل الدخول2| ”اوها .يحفظ الحقل الخاص Dا”iوهاواO‏ 
نسخة من معرف تسجيل الدخول ۱0 "اوها عند فتح الفورم للمرة الأولىء ويتفحص من أجل أي تفيرات عند إعادة حفظ السجل.إذا ما حدثئت 
تغيرات»فإنه يعيد توليد كلمة المرور. 

passwordResult = EncryptPassword (Trim (RecordLoginID.Text), Trim (RecordPassword.Text) ) 

استخدام نماذج التحرير N۳٠‏ ۲ءءلاو م۳ مده 6يتطلب بعض الكود الإضافي في الفورم الرئيسي١١٥؟‏ ١أ"‏ .أضفه إلى جسم الكود المصدري 


للفورم الرئيسي: 
Bia te SMD AOMIDEINEGEOUSS Min KE NNE KedBYUAN Sende AS Oeecty, BUI e HS‏ 
System.Windows.Forms.LinkLlLabelLinkClickedEventArgs) Handles AdminLlLinkGroups.LinkClicked‏ 
Let the user edit the list of security groups.‏ ج 
دع الاتحدم جرر انمه خمروعات الامن. 
If (SecurityProfile (LibrarySecurity.ManageGroups) = False) Then‏ 
MsgBox (NotAuthorizedMessage, MsgBoxStyle. OkOnly Or _‏ 
MsgBoxStyle.Exclamation, ProgramTitle)‏ 
HE EUR‏ 
ل 
Edit the records.‏ ڪڪ ي 
1 ا 
ListEditRecords.ManageRecords (New Library.GroupName)‏ 
Li SEEd1 ERecGOEAS = NOLhHING‏ 


Mhm76 الفصل الحادي عشر:الأمن‎ 
ERG Sub 
Erivate SUS AMIRI RNEUSEES MAKE INEKed (EvYVal Sender AS Oo ect, BVVal e AS 
System.Windows.Forms.LinkLabelLinkClickedEventArgs) Handles AdminLinkUsers.LinkClicked 
Let the user edit the list of administrative users. 
ا کا ا ا ا ق‎ 0 1 
If (SecurityProfile (LibrarySecurity.ManageUsers) = False) Then 
MSGEOX (NOEAUE ROE zedMes sage, MSTEOxXS Lyle. OKOnly Or 
MsgBoxStyle.Exclamation, ProgramTitle) 
ReEUrEn 
ERO UE 
چ‎ Edit the records. 
جرزبزر ا‎ 
ListEditRecords.ManageRecords (New Library.UserName) 
ListEditRecords = Nothing 
End SUS 


الأدوات Admin Link Groups‏ و ink Users‏ minههي‏ لصاقات وصل نمطية الويب كامطها ٠ا‏ ماراء-طهس والتي أضفناها للبرنامج من عدة فصول 
سابقة.الحدث ١ءءا٥)اوليس‏ الحدث ١ء»ءااع‏ هو من يطلق العرض لمحرر الكود.إليك الكود الذي يحرر جدول ص۸2 مuهاG.‏ 


Bri va te SUD ASMA RLIREEGrEOUSS inkEl eked (ByVal Sender AS Oo ect, BVA © AS 
SS ES Wino. Forms.LinkLlLabelLinkClickedEventArgs) Handles AdminLlLinkGroups.LinkClicked 
کے ا‎ Let the user edit the list of security groups. 
ع لادم جرر فاته عموعات امن‎ 
If (SecurityProfile (LibrarySecurity.ManageGroups) = False) Then 
MsgBox (NotAuthorizedMessage, MsgBoxStyle. OkOnly Or _ 
MsgBoxStyle.Exclamation, ProgramTitle) 
HE UE 
ال اا‎ 
am Edit the records. 


ListEditRecords.ManageRecords (New Library.GroupName) 


ListEditRecords = Nothing 
End SUS 
Per-User Experience. Jآ‎ ةıرجت‎ 
والآن بما أن لدينا كل كود دعم الأمن المضاف إلى المشروعءنستطيع البدء باستخدام هذه الميزات لتفير تجربة التطبيق من أجل الزبائن والمدراء.‎ 
ليس من الخُلق إغراء الناس بالقوة الهائلة.لذلك من الأفضل إخفاء هذه الميزات والتي هي غير قابلة للوصول بالنسبة للعملاء المستخدمين المتواضعين‎ 
وبشكل أساسي أقل قوة.‎ 
اول لنوفر القوة المتنوعة بإضافة نموذج تسجيل دخول الاداري المبين في الشكل التالم.‎ 


اتصل تمستخدم مدير ءأو ارجح إلى تمط الحميل 


الرجوع إلى نمط العميل 
الاتصال كمس دم مدر 


مرف الد | 


تلمة الفرور: 


لقد عملت سابقاً على إضافة النموذج ط۷.إ#ءلا#و,ة۸© إلى المشروع العمل الصعب في الفورم يحدث في اي معالچ الحدث»ءنا۸c)0K۸_C‏ .إذا ما 
اختار المستخدم"الرجوع إلى نمط العميل"»جميع قيم الأمن يتم تنظيفهاءوالفورم الرئيسي تخفي معظم الميزات(من خلال كود سيضاف فيما بعد) 
LoggedInUserlD = -1‏ 
LoggedInUserName = ""‏ 
LOGTEQdIRGr oUpID 1‏ 
ReprocessSecuritySet ()‏ 


تعمل هذه الفورم على الاأتصال إلى التطبيق من خلال الفورم الرئيسي وذلك من خلال الحدثعءنا٥_”اوم‏ ااه .افتح ملف الفورم الرئيسي 
.MainForm.vb‏ انقر مزدوج على زر ١اوه‌افي‏ الزاوية العلوية اليسارية.وأضف الكود التالي لحدتث النقر الذي يظهر. 


E val Ee SUS ACEO SED CIE E NBYVAN SERNIEE AS CVUSEEM ODN EGE EVVal CG EAS EVSEEM SEVEN EASES) HORIUES 
AE ELON CIMER 
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أضف الكوة الالي لفون أيضا 


e Sub 


DAM 


Then 


لنمكن أيضاً المفتاح 12 ليتصرف كمطلق للدخولمنوه! .أضف الكود التالي إلى عبارة "اختر حالة 6ة ء٠ام8‏ " في معالج حدث 


.MainForm_KeyDown 


يستدعي الروتين "۴٥۲"‏ iوهاسهط5طريقة‏ أخرى. ۲مءل۲ه۴رهامءiصءاaهملا.والتي‏ تخفي وتظهر عناصر العرض المتنوعة على الفورم الرئيسي 
بالاعتماد على شكل الأمن ءاا؟هإم رانء للمستخدم الحالي.أضفها إلى كود فئة النموذج الرئيسي٣١٠۴”‏ 1ة .وهو ينظر بشكل أساسي إلى المتغير 
Dاserلnاedوو10ءوإذا‏ ما تم وضعه إلى -1.فإنه يخفي جميع الأدوات بالنسبة للميزات المتقدمة. 
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حالياًعندما نشفل التطبيق»جمبع الميز ات المتقدمة تظهر»حتى ولو لم يكن قد زود مدير بالمعرف 0| أو كلمةالمرورك55«W0۲هم‏ .استدعاء 
For User‏ ayاUpdateDisp‏ عندما يظهر الفورم الرئيسي للمرة الأولى يحل المشكلة.أضف الكود التالي إلى نهاية الطريقة 024ا_ "۴0۲" .Nai‏ 
1 الاجا للمستخدم الل 
UpdateDisplayForUser ()‏ 


التحديث الأخير (عملياًء خمس تحديثات)يتضمن وضع حدود المقاطع الرئيسية للفورم لضبط المدراء المرخص لهم.على سبيل المثالءفقط المدراء 
المرخص لهم بتشغيل التقارير يجب أن يكونوا قادرين على الوصول إلى لوحة التقارير على الفورم الرئيسي.أوجد الطريقة كاهم5۸86ة٣في‏ الفورم 
الرئيسي»وأوجد السطر الذي يعرض اللوحة. 


بطل فا الط بالكوة التالى 


If (SecurityProfile (LibrarySecurity.RunReports) ) Then PanelReports.Visible = True 
.في كل حالة بدل السطر الذي يقرا:‎ ask Processو‎ rask Admin « ۲ء‎ ask C1٥ c)0 u نحتاج لعمل نفس الشيء في الطرق‎ 


Panel 272Visible = True 
بالكود الذي يختبر إعدادات امن قبل إظهار اللوحة.‎ 
.TaskCheckOut Jجi‎ jo يلاتلl بالكو‎ PanelcheckOut.Visib1e = True فبدل السطر التالي‎ 


PanelReports.Visible = True 


.TaskCheckln Jجi‎ jo بالكود التالي‎ Panel check 1¬ .V1s1ط1e‎ = 1r uء وبدل السطر التالي‎ 


وبدل السطر التالي ue‏ ء7 = 1eظطPanelAdmi¬.v1s1‏ بالكود التالي من أجل الطريقة .TaskAdmin‏ 


بدل السطر التالي ءuء7‏ = 101ء71 ane1 Process.‏ بالكود التالي من أجل الطريقةءءهءه۴۲ )كه . 


شَفَّل البرنامج وسترى أن بدايته تيدو كتطبيق حقيقي.إذا حاولت الوصول إلى الميزات المحسنة»جرب معرف تسجيل الدخول " ١أ"‏ له "ويدون كلمة 
مرور. تستطيع تفير ذلك من خلال نموذج ۳ه۲ءولاإذا أردت. 

بما أنه لدينا طريقة لتأمين الوصول إلى البيانات والميزات بالنسية لمشروع المكتبة.لذلك لننتقل إلى الفصل التالي ونبدأً بالتركيز على البيانات. النقطة 
المركزية لأي تطبيق عمل. 
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الفصل الثاني عشر:إعادة التعريف والامتدادات Mhm76‏ 
إعادة التعريف وlںoتدlڏlٽت Overloads and Extensions‏ 

بدايةء إن الفيجوال بيسك تدعم إعادة تعريفو”i١١٥)۲ع۷٠‏ اهعمد المعاملات مثل الجمع(+).هذا الفصل سيريك كيف تستطيع توجيه عملية تحسين البناء 

الجسدي من أجل معاملات الفيجوال بيسك المتنوعة.وسأقدم لك أيضاً طرق الامتداد(التوسبع i0۸ء١ء)×٠‏ )ءوالتي تتبج لك بشكل مشابه تحسين الفئات»حتى ولو لم يكن 

عليك الوصول إلى الكود المصدري الأصلي لهذ الفئات. 


تتيح عملية إعادة تعريف معامل لكودك تحسين معاملات الفيجوال بيسك الأساسية وتمنحهم إمكانيات غير متوفرة لديهم سابقاً بواسطة المترجم.إعادة التعريف لا تغير 
البناء المستعمل عند توظيف المعاملات»ولكنها تغير نوع الكائنات التي يديرها كل معامل.على سبيل المثالمعامل الضرب(*)عادة يتفاعل مع الأعداد فقط ولكن تستطيع 
تضخيمه للعمل مع فئة مثل "النحلة الطنانة ٠عطءاط‏ "ن8 " التي تخصصها أنت. 
Dim swarm As Bumblebee‏ 
Dim oneBumblebee As New Bumblebee‏ 
Dim twoBumblebee As New Bumblebee‏ 
swarm = oneBumblebee * twoBumblebee‏ 
المعنى الذي تطبقه على المعامل المعاد تعريفه عائد لك.على الرغم من أنك عندما تريد أن تحتفظ بالنوع المضاف لمعامل الجمع (الاضافة) عند إعادة تعريفه.فليس عليك 
عمل هذا.في الحقيقة.تستطبع إعادة تعريف معامل الإضافة بحيث يعمل على طرح قيمة من أخرى.ولكنني سأطردك من العمل عندي إذا عملت ذلك.هذا فقط كي تعلم أنه 


جمبع ميز ات إعادة تعريف معامل مرتيطة بشكل مباشر بواحد أو أكثر من فئاتك.تبدو الميزات المعاد تعريفها مثل أعضاء دالة قياسية تقربياًوتظهر كأعضاء لفئاتك. 
تتضمن الفيجوال بيسك نوعين من المعاملات:أحادي ٠٣٥۲‏ والثنائية ۶٩ط‏ »معرفة تبعاً لعدد العوامل(أطر اف المعامل) المميزة بواسطة المعامل.تقبل المعاملات 
الأحادية طرف(عامل) واحد فقطءوالذي يظهر دائماً على يمين اسم المعامل أو الرمزاهطا"”رء .فمنطق المعامل "ليس اه "هو معامل أحادي: 
oppositeValue = Not originalValue‏ 
تقبل المعاملات التنائية عاملين(طرفين)واحد على كل جهة من المعامل.فمعامل الضرب هو معامل تنائي: 
ten = two * five‏ 
طبيعة معامل ما هي ما يعمله مباشرةء في الحقيقة يتم استبدال المعامل وعوامله(عامله) المدخلة بالنتيجة المحسوبة.فمثلاً التعبير (10/5)يتم استبداله بالنتيجة 
المحسوية(2)ءوهذه النتيجة يتم استخدامها لاإتمام عبارة ما أو تعبير عملية أصلية يظهر ضمنه المعامل وعوامله.فهو يعمل تماماً كدالة: 
'السطرين التاليين يعملان نفس الشيء 
' النتيجة المحسوبة في المتغیر ۸٥۴۸۸۷۴۲‏ 
theAnswer = 2*5‏ 
theAnswer = Doublelt(5)‏ 
ليكون معامل جاهز لاإعادة التعريف»غير تفكيرك لترى المعاملات كدوال.انظر عبر حدود بيئة معاملك»وافتح عقلك إلى حقيقة أن المعاملات والدوال هي واحدة. 
تعريف إعادة تعريف المعاملات في الفيجوال بيسك كما يليءإذا كان عليك ترجمة تعريف الضرب إلى دالة فيجوال بيسكءيمكن أن تبدو كالتالي: 
Public Shared Function *(ByVal firstOperand As Integer, ByVal secondOperand As Integer) As Integer‏ 
المعامل(*)يصبح اسم الدالةءمع العوامل كك ”هعم التي تلعب دور وسيطات الدالة. أخيرآً ءتوليد القيمة المعروضة من خلال القيمة المعادة بالدالة.على الرغم من أن 
المعاملات ا يتم تعريفها كدوال بهذه الطريقة في الفيجوال بيسك.ولكن إعادة تعريف هذه المعاملات يتم تعريفها كدوال. 
لإعادة تعريف معامل الضرب في فئة ءعطءاط" Bu‏ الخياليةءنستخدم الكلمة المحجوزة ۲0۲٠م‏ 0لتعريف"دالة الضرب ٣‏ ١٥ا†func‏ tiplicationاmu‏ "من أجل 
.Bumble bee ةãidll Jolge‏ 
Partial Class Bumblebee‏ 
Public Shared Operator *(ByVal operand1 As Bumblebee, _‏ 
ByVal operand2 As Bumblebee) As Bumblebee‏ 
Multiply two bumblebees together.‏ ' 
Dim finalResult As New Bumblebee‏ 
Add special "multiplication" code here, then...‏ ----- ' 
Return finalResult‏ 
End Operator‏ 
End Class‏ 
والآن عندما تضرب حالتي ١ع٤طءاط 8u‏ مع بعضهما بمعامل الضرب.تميز الفيجوال بيسك النموذج"عامل1*عامل2" كمطابقة لاإعادة تعريف معامل الضرب مع 
معاملين نسبيين من نوع ع عطءاط "81 وتستدعي هذه الفئة بالا عتماد على دالة المعامل للحصول على النتيجة. 
جميع التصريحات عن المعاملات يجب أن تتضمن الكلمة المحجوزة ان۴ والكلمة المحجوزة 5۸3۲8۵ | .فإذا لم تكن متشار كة.۵٠12۲ء‏ سيكون على الفيجوال بيسك 
طلب إنشاء حالة إضافية من الفئة من أجل الوصول لكود إعادة تعريف المعامل فقط وذلك لن يكون فعال جداً. 


تستطبع إلى حد ما إعادة تعريف أي معاملات قياسية للفيجوال بيسك(ما عدا المعامل ء1 والمعامل†هلء] )زائد عدة ميزات أخرى.يشرح هذا الفصل كل معامل قابل 
لاإعادة التعريف»مصنف بواسطة النوع العام.كل مقطع يتضمن جدول بالمعاملات.لاعادة تعريف معامل في فئةء استخدم الاسم في عمود المعامل كاسم للدالة.إذا كان هناك 
معامل مسمى ××ءستكون عيارة المعامل المطابقة كما يلي: 

Public Shared Operator XX(...) 


الفصل الثاني عشر:إعادة التعريف والامتدادات Mhm76‏ 
تعرف الفيجوال بيسك 10معاملات رياضية أو معاملات رياضية مستعارة(شبه رياضية) ا2ء 21١٣ع‏ 1ة"-دلuعءم‏ .جميعها لمعاملة الأعداد ما عدا واحد..المعامل 
الباقي هو مسلسل النصوص ١‏ 0٥|اة١عاةء١ه»ء‏ و١‏ ۲ء (&) ولكن يبدو مثل باقي المعاملات الرياضية في بناءه واستخدامه. 
معاملين من المعاملاتءالزائد كuام‏ (+) والناقص ءد”ا" (-).هما معاملات أحادية ة١‏ دوتنائية رهط .إشارة الناقص ٣وا us‏ اص تعمل كمعامل"نفي 
ationوeہ‏ "أحادي كما في("-5")وكمعامل "طرح ١٥ا‏ ه٣اطنء‏ "تنائي(البناء "2-5"المعروف).عندما إعادة تعريف هذ المعاملاتءالاختلاف الموضوع في عدد 
المعاملات النسيية المضمنة في توقبع المعامل يحدد أي منها أحادي أم ثتائي. 
Public Shared Operator -(ByVal operand1 As SomeClass) As SomeClass‏ 
This is the unary "negation" version.‏ کد 
End Operator‏ 
تجدول القائمة التالية المعاملات الرياضية التي تدعم إعادةالتعريف: 


Binary +‏ معامل الإضافة(الجمع)القياسي.تذكر .فقط لأن المعامل يدعى معامل"إضافة"لايعني أن عليك حفظ ذلك 
المفهوم.مهما يكنء عليك المحاولة في إعادة تعريف المعاملات كأقرب ما يمكن لمعناه الأصلي قدر 


اانا حال وك ها دد فة هى الل ام ك اعرف ق مل لال دلت ال 


معامل الطر ح٩ subtracti٥‏ . 


. standard division o0pera†0]يسايقلا معامل القسمة‎ 


(" to the power of jo ögãl") exponentiation معامل الدلیل أو لس‎ 


معامل سلسلة النصوص ؟r2†0۲€°° .string concatenation‏ 


تتضمن الفيجوال سبع معاملات مقار نة أساسية»معظمها يتم استخدامه في عبارة ۴آو التعابير المشابهة والتي تتطلب حساب شر وط منطقية 8001۴0۸ . طرق المعامل 
peat‏ 0من أجل معاملات المقارنة هذه لها نفس البناء الذي تم استخدامه في المعاملات الرياضية»ولكن معظمها يجب أن يتم معالجته بشكل زوجي. على سبيل 
المتالء إذا أعدت تعريف المعامل(أقل من >)ءتطلب منك الفيجوال بيسك إعادة تعريف المعامل(أكير من < )أيضاً ضمن نفس الفئةومن أجل نفس توقبع المعامل النسيي 
.argument signature‏ 
جميع معاملات المقارنة هي معاملات منطقية.على الرغم من أنك تستطبع تبديل نوع البيانات للمعاملات النسبية الممررة للمعامل»ويجب أن تعود كلها بقيمة منطقية. 
Public Shared Operator <=(ByVal operand1 As SomeClass, ByVal operand2 As SomeClass) As Boolean‏ 
The <= operator returns a Boolean result.‏ کک 
End Operator‏ 
القائمة التالية تجدول سبع معاملات مقارنة أساسية والتي تستطيع إعادة تعريفها.وكل مدخلة تتضمن قيمة"المصاحب رلك اط "والتي تحدد المعامل الموافق والذي يجب 
ن يتم إعادة تعريفه. 


يقارن معامل عدم المساواة عاملين من أجل عدم التساوي»ویعود بصواب إذا كانا غير متطابقين. 


يعود المعامل أكير من بصواب إذا كان العامل الأول"أكثر من ٣2٣ا‏ ۲هن "الثاني 


يعود المعامل أكثر من أو يساوي لءبصواب إذا كان العامل الأول "أكير من أو يساوي ل 
greater than or equal to‏ "للتاني. 


الفصل الثاني عشر:إعادة التعريف والامتدادات Mhm76‏ 
معامل المقارنة السابع هوه )ا .في الفيجوال بيسك القياسيءيعمل هذا المعامل على مقارنة العامل الأول إلى"نموذج١٣٠ااةم‏ "نصي.والذي هو مجموعة من الحروف 
المتطابقة والقيم الشاملة sلa۲ءل|أW‏ . 
If (ssomeValue Like somePattern) Then‏ 
ليس عليك استخدام نفس قواعد النموذج ١۲٠ا٤ةمعند‏ إعادة تعريف المعامل k٠‏ أاوتستطبع أن تقبل أي نوع بيانات من أجل عامل النموذج١۲٠ةم‏ » ولكن يجب 
عليك دائماً العودة بنتيجة منطقية "2ع ا800 . 
Public Shared Operator Like(ByVal operand1 As Bumblebee, ByVal operand2 As Integer) As Boolean‏ 
See if Bumblebee matches an Integer pattern.‏ ----- ' 
End Operator‏ 
ايوجد معامل "مرافق “رل لاط " والذي يجب عليك معاملته عند إعادة قيادة المعامل ع kاا.‏ 


و ن ي اا ال او و ا ل 2 و اوا ر ت واک اف اا 
معاد تعر يفها.تقبل المعاملات على مستوى البت(وحدة تخزينية)( وهي ١۵١4ء‏ 0۲0۲× و اهل )عوامل عددية صحيحة۲٥و1۴"١|‏ »وتولد نتائج عددية مع القيم 
المنقولة(المرسلة) على مستوى الوحدة التخزينية المستقلة. وهي تعمل أيضاً كمعاملات منطقية.تقبل وتعيد قيم منطقية٣2ا800.على‏ الأغلب في العبارات 

الشرطية ولكن يامكانها معالجة الضغط كونها قاباة لإعادة القيادة أكثر بقليل. 

عندما تعمل على إعادة قيادة ٥ل٠۲۲٠۷٠هذه‏ المعاملات الأربعءفأنت تعيد قيادة إصدارات على مستوى البت (الوحدة التخزينية)۸5٥‏ ء۲٥۷‏ مءاساط ولیس 
لاف ال افو ك أعامك ي أن لك تك عاك اله الوعاك ون طا كا مووق 

تخكول القاتدة انال تماة مفاملات على مستوف الوخة التخر رة والمتطقة القابلة لأعاة التعريقه 


>> يعمل معامل الرفع اليميني وا۲ ا۴؟أاءرفع وحدة تخزينية تماما مثل معامل الرفع اليساري»ولكن تنقل الوحدات التخزينية في اتجاه "اليمين 
اوا ".إني أظن أن هذا سيجعل هذه الوحدات التخزينية أكثر محافظة٠۷اة۲۷ءء١‏ ٠ء‏ .يمكن لكودك أن يجهل القيمة المعادة أكثر تساهلاً إذا 
أردت.ولكن كما مع معامل الرفع اليساريءيتوجب عليك قبول عدد صحبح #۲و٠۲”[كعامل‏ ثاني. 

And‏ معامل ربط ١٥ااء"‏ ازم هءعلى مستوى الوحدة التخزينية يضع وحدة تخز ينيةاط في القيمة المعادة إذا ما تم إعداد وحدتي تخزين على حد سواء 
متوضعتين في عوامل المصدر. 


بالتساوي في عوامل المصدر تم إعداده 


. A۸۵۸ ۸و0ءا‎ ٩ ولدیه نفس القواعد»ولكن يقدم إلى المعاملات‎ 1٩۲٥ إعادة تعریف ۵ا۴۵ ءآیعمل تماما مثل‎ IsFalse 


تبدو ميزة الفيجوال بيسك ءمرآ أكثر شبها لدالة منها لمعامل: 
result = CType(source, Type)‏ 
ولكن المظاهر خداعةو”ا۷أمءع ١ة‏ ء)هه! .فهي ليست دالة حقيقية.وكما مع دوال التحويل الأخرى(مثل ٤١1))ءيتم‏ معالجتها عملياً وقت التر جمة. قبل تشغيل 
اليرنامج بوقت طويل.من خلال السماح لك بإعادة تعريفها كالمعاملءتمكنك الفيجوال بيسك من إنشاء تحويلات 5١0ء۲‏ ٠۷١٥ء‏ نوعية وخاصة بين أنواع البيانات التي 
لاتبدو منسجمةهاط نةم هء» .قالب الطريقة التالية يحول قيمة من نوع عع6ءاط 8u‏ إلى عددي صحيح 1t ege‏ . 
Public Shared Operator CType(ByVal operand1 As Bumblebee) As Integer‏ 
Perform conversion here, returning an Integer.‏ ----- ' 


الفصل الثاني عشر :اعادة التعريف والامتدادات Mhm76‏ 
End Operator‏ 

إذا حاولت كتابة المقطع الأخير من الكود ضمن الفيجوال بيسكءسيعترض ١اهام‏ ١٥ء‏ أنك تفقد إما الكلمة المحجوزة و” ال۷1 أو الكلمة المحجوزة 

9 Narrowin(شاهد‏ الشکل التالي). 


Lonyersion operators must be declared either Widening’ or Narraming'. 


Public Shared Operator E operandl Ais Bumblebee] As [Integer 


Perform CONTE DH HEEE, EFEEUERHLIAG AB IAEEGEE 
End GperatorE 


لقد ذكرت تحويلات التوسبع و”أسW٠٣2۲”والتضبيق‏ و١١‏ ءل سفي الفصل التثانيء ولكن لنختبرها هنا بعمق أكثر.عندما تحول بين بعض أنواع البيانات الجوهرية 
في الفيجوال بيسك »يوجد فرصة لأن يفشل التحويل في بعض الأحيان لأن القيمة المصدرية لا تتناسب في القيمة المقصودة.وهذا صحبح عند تحويل قيمة لنوع قصير 
Byteiıl J|Short‏ . 
Dim quiteBig As Short = 5000‏ 
Dim quiteSmall As Byte‏ 
سيفشل السطرين التالبين ' 
quiteSmall = quiteBig‏ 
quiteSmall = CByte(quiteBig)‏ 
وإنه من الواضح لما يفشل التحويل:المتغير من النوع بايت لايمكن أن يحفظ قيمة 5000.ولكن ماذا حول هذا الكود؟ 
Dim quiteBig As Short = 5‏ 
Dim quiteSmall As Byte‏ 
These next two lines will succeed.‏ ----- 
quiteSmall = quiteBig‏ 
quiteSmall = CByte(quiteBig)‏ 
إنه يعمل بشكل جيدءبما أن 5 تتناسب ضمن المتغير بايت مع مساحة احتياطية.(إذا كان خيار التدقيق ا٣5‏ ١هنام0‏ تم وضعه إلى فعال"0 ءفإن الإسناد الأول 
سيفشل في الترجمة)ء مع ذلك.لايوجد شيء يوقفني عن إسناد قيمة 5000إلى المتغير و81ااناووتجريب الاإسناد مرة أخرى.هذا احتمالي ا١اہ‏ ع٤همالفشل‏ خلال 
التحويل وهذه هي القضية. 
عندما يكون للتحويل احتمال الفشل تبعاً لكون البيانات المصدرية غير قادرة على أن تتناسب بالكامل في المتفير المستهدف.فإنه يدعى تحويل التضیييق ۸٩۲۲٥W ٣9‏ 
version‏ con.تحويلات‏ التضييق 10۸ء۲ع۷١‏ ٥0ء‏ و ٩/٣٥١ W‏ هي حقيقة.وطالما أنك قد اختبرت البيانات قبل التحويل.فلن يكون هناك أي سيب لتقيد مثل هذه 
التحويلات بشكل تابت. 
تذهب تحويلات التوسيع 15 i0ءعnvهc iden in9‏ في اتجاه معاكس.فهي تحدث عندما تتناسب أي قيمة مصدرية في نوع البيانات المصدري في النوع الهدف 
دائما.تحويلات التوسبع ستنجح دائماً طالما أن البيانات المصدرية محققة. 
تسمح الفيجوال بيسك للتحويلات التوسبع أن تحدث بشكل آليءوبشكل ضمني.ليس عليك بشكل صربح استخدام ءمرآ٤لجبار‏ التحويل.إذا كان لديك تحويل توسيع من 
فنة ٠ع‏ طعاط 8u‏ إلى العددي الصحبح۲٠‏ و۴١1‏ .وقد وضعت خيار التدقيق †ءأ٣†؟S‏ ١٠اام0‏ إلى فعال0۸ ءفإن الكود التالي سيعمل جيداً: 
Dim sourceValue As New bumblebee‏ 
Dim destValue As Integer = sourceValue‏ 
إذا كان التحويل من إلى تضييق»فسيكون عليك إجبار التحويل باستخدام ءمر آ٣‏ وذلك للتأكيد على الفيجوال بيسك أنك تريد عمل هذا : 
Dim sourceValue As New bumblebee‏ 
Dim destValue As Integer = CType(sourceValue, Integer)‏ 
عندما تعمل على إنشاء تحويل مخصص مع المعامل ءمرآالمعاد تعريفه»يتوجب عليك إعلام الفيجوال فيما إذا التحويل هو توسبع أو تضبيق ودلك بإدخال إما الكلمة 
المحجوزة و”اعلi¥‏ أو الكلمة المحجوزة و”iسه2۲۲ل‏ بين الكلمة المحجوزة ٣2۲٥١‏ كوالكلمة المحجوزة2†0۲ا هم0 . 
Public Shared Narrowing Operator CType(ByVal operand1 As bumblebee) As Integer‏ 
Perform narrowing conversion here.‏ ڪڪ ا 
End Operator‏ 


يوجد أيضاً العديد من القواعد التي يجب عليك إتباعها عند إعادة تعريف المعاملات»ولكن في البداية لنلقي نظرة على شبه الفثة ٠عطءاط‏ ن8 المفيدة . 

Class Bumblebee 

Public Bees As Integer 

Public Sub New(0 
= Default constructor. 

Bees = 0 
End Sub 
Public Sub New(ByVal startingBees As Integer) 
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----- Assign an initial number of bees. 
Bees = startingBees 
End Sub 
Public Shared Operator +(ByVal operand1 As Bumblebee, ByVal operand2 As Bumblebee) As Bumblebee 
' ----- Join bumblebee groups. 
Dim newGroup As New Bumblebee 
newGroup.Bees = operand1.Bees + operand2.Bees 
Return newGroup 
End Operator 
Public Shared Operator -(ByVal operand1 As Bumblebee, ByVal operand2 As Bumblebee) As Bumblebee 
----- Separate bumblebee groups. 
Dim newGroup As New Bumblebee 
newGroup.Bees = operand1.Bees - operand2.Bees 
If (newGroup.Bees < 0) Then newGroup.Bees = 0 
Return newGroup 
End Operator 
Public Shared Operator *(ByVal operand1 As Bumblebee, ByVal operand2 As Bumblebee) As Bumblebee 
_ Create a swarm. 
Dim newGroup As New Bumblebee 
newGroup.Bees = operand1.Bees * operand2.Bees 
Return newGroup 
End Operator 
Public Shared Widening Operator CType(ByVal operand1 As Bumblebee) As Integer 
' Perform conversion here. 
Return operand1.Bees 
End Operator 
End Class 
الفئة بسيطة لحد ماءفهي موجودة لحفظ عدد بسيط من النحلات.ولكن بإعادة تعريف المعاملات الإضافة. الطرح.الضرب »و"تحويل النوع".نستطبع استخدام حالات من‎ 
النحلات مع بناء أكثر واقعية.‎ 
Dim quiteBig As Short = 5 
Dim studyGroup1 As New Bumblebee(20) 
Dim studyGroup2 As New Bumblebee(15) 
Dim swarmGroup As Bumblebee = studyGroup1 * studyGroup2 
MsgBox("The swarm contains " & CInt(swarmGroup) & " bees.") 


شفل الكود بشكل صحبح يولد الرسالة المبينة في الشكل التالي: 
YWYIindowsA pplication] *)‏ 


The swarm contains 3UU bees. 


موائی 


تضمين إعادة تعريف ۵م۷٣٣‏ والتي تولد عدد صحبح ۲٥و٣‏ !يسمح لي تحويل ١٤٥٤ء‏ اط ن 8باستخدام المعامل†١1)‏ .وأستطبع أيضاً تفير السطر الأخير 
لاستخدام المعامل عءم۷١0‏ الصحيح. 
MsgBox("The swarm contains " & CType(swarmGroup, Integer) & " bees.")‏ 


كما ذكرت سابقاًءيتوجب عليك جعل طرق المعامل عامة ومتشار كة١٠۲ه۸؟‏ نا۴ .ولأن المعاملات المعاد تعريفها تحتاج نوعاً ما اتصال حميم بالفئة الحاوية 
عليهم» على الاأقل واحد من العوامل أو القيمة المعادة يجب أن تطابق نوع الفئة المحتوية.(في بعض إعادة التعريفءتتطلب الفيجوال بيسك أن يكون واحد من المعاملات 
متطابقة) أي من إعادة التعريف التالي سيعمل تماماً وبشكل جيدبما أن ال عع طءاطص ن 8يتم استخدامها لواحد من المعاملات: 
Public Shared Operator <=(ByVal operand1 As Bumblebee, ByVal operand2 As Integer) As Boolean‏ 
Compare a bumblebee to a value.‏ ----- ' 
End Operator‏ 
Public Shared Operator < =(ByVal operand1 As Date, ByVal operand2 As Bumblebee) As Boolean‏ 
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----- Compare a date to a bumblebee. 

End Operator 

مهما يكن لانستطبع وضع كلا العاملين إلى نوع غير النوع ٠ع‏ عاط 8u‏ في نفس الوقت.وتيقى محتفضاً بإعادة التعريف في فئة #عbء‏ اط .8u‏ 

Class Bumblebee 

Public Shared Operator <= (ByVal operand1 As Date,ByVal operand2 As Integer) As Boolean 
.هذا لن یتم تر جمته ج‎ 

End Operator 
End Class 


تستطبع إعادة تعريف المعاملات المعاد تعريفها.فيمكذك إضافة تنوعات لعدة تواقيع للقيم المعادة والمعاملات النسبية لمعامل معاد تعريفه لفئة مفردة. 
Public Shared Widening Operator CType(ByVal operand1 As Bumblebee) As Integer‏ 
.اعمل تحويل إلى عدد صحيح هنا ' 
End Operator‏ 
Public Shared Widening Operator CType(ByVal operand1 As Bumblebee) As Date‏ 
.اعمل تحويل إلى تاريخ هنا خت .۱ 
End Operator‏ 
طالما أن تواقيع المعامل النسبي كعإناة٠واء‏ ٤"ع"يو”ة‏ أو القيمة المعادة مختلف»تستطبع إضافة العديد من إعادة تعريف المعامل كما تشاء.لا تحتاج إلى استخدام 
الكلمة المحجوزة كdھهاام0vايضا‏ 


ماذا بشأن الرغبة في تعديل سلوك فئة ماءولكن ليس لديك إمكانية الوصول إلى كودها المصدري؟تستطبع الاشتقاق منها وتبني فئة جديدة»ولكن هذا ليس مناسب 
دائماً.تستطبع الاتصال بالمطور الأصلي وتترجاه من أجل الكودولكن بعض هؤلاء المبرمجين بخيلين جداً ١6اءا؟-ا‏ واا عندما يتعلق الأمر ببرمجياتهم. 
يوجد خيار أخر وهو استخدام ميزة الفيجوال بيسك2008 الجديدة :وهي طرق التوسيع (التمديد)ءd‏ ه۸٤٥١‏ ١i0ء٠ع×e‏ .إليك كيفية العمل: 
1.إنك تقرر أي فئة تريد توسيعها بالطرق الجديدة. 
2.تكتب هذه الطرق ضمن وحدة برمجية ءاu‏ له قياسية في كودك المصدري. 
3.تيدأ باستخدام الطرق الجديدة وكأنه تم تضمينها في تعريف الفئة. 
يتضمن نوع بيانات السلسلة الحرفية وذ٣5‏ (النصية) العديد من الطرق الجاهزة(المبنية داخلياً) والتي تعود بنسخة معدلة لنسخة سلسلة حرفية.على سبيل المثالء في 
هذا الكود: 
Dim bossyString As String = "are you talking to me?"‏ 
MsgBox(bossyString.ToUpper())‏ 
النص الذي يظهر في صندوق الرسالة سيكون كله في الحالة الكبيرة #ءةء۲ءمم نلان الطريقة ٣م‏ ملاه"آ تعود بنسخة حالة كييرة جديدة من حالة (نسخة) النص 
الأصلي. الطريقة المطابقة ٠١‏ ۷٠ا١۲تعمل‏ بطريقة أخرى(تحول الأحرف إلى الحالة الصغيرة).ولكن ما أريده بالفعل هو الطريقة "إلى عنوان ٠٠١٣٠٥‏ "والتي تكبر 
فقط الحرف الأول لكل كلمة. 
MsgBox(bossyString.ToTitle( ))‏ 
ولكن فئة السلسلة الحرفية لا تتضمن الطريقة" ا۲١٠٠"‏ ولكن نستطبع إضافتها بفضل طرق التوسبع(التمدد).لإنشاء طريقة تمددأنشئ طريقة ضمن وحدة برمجية 
eاu nd‏ قياسية بحيث تقبل نوع البيانات المستهدفة كوسيط أول لها. 
Module MyExtensions‏ 
<System.Runtime.CompilerServices.Extension()> Public Function ToTitle(ByVal sourceText As String) As String‏ 
Return StrConv(sourceText, VbStrConv.ProperCase)‏ 
End Function‏ 
End Module‏ 
بالعادة.ستستدعي هذه الدالة كتمرير في السلسلة الحرفية الأصلية 
MsgBox(ToTitle(bossyString))‏ 
وذلك الكود سيعمل تماماًولكن الزيادة في مواصفة التوسيع(من فضاء الأسماءكعع System.Runtime.Com م¡اerSمe vi‏ )تحول eاit‏ إلى طريقة 
توسيعءتوسع نوع البيانات النصية.إن كودك في الحقيقة لا يعدل نص.خلف الكواليس» يعمل متر جم الفيجوال بيسك على تحويل بناء الطريقة المشابهة الجديدة "٥۷W‏ 
method -اike syntax‏ إلى بناء الدالة المشابهة القديمة ×ه†٣رء‏ ikeا-function‏ dاoفي‏ کل استخدام ل ٥ا٤¡‏ آہا. 
بنفسها طرق التوسبع لاتعمل الكثير.استدعاء (9٣٣†y5ءءهe)6|ا†|‏ اه1 يختلف عن ( )٥اه‏ ۲.و١ا†۷5Sء0sط.ولكن‏ كما مع العديد من الميزات الجديدة في 
الفيجوال بيسك2008ءطرق التوسبع تم إضافتها فقط لرفع ءءأه۲سعر المنتج.إني أمزحءإن ميزة طرق التوسيع الجديدة دعم هام من أجل تقنية لينكو @111الجديدة. 


سنضيف الكثير من الكود في مشروع هذا الفصل إلى تطبيق المكتبة. أكثر من %25من أساس الكود الكامل.معظمه مشابه للكود الذي أضفناه في الفصول السابقةءيوجد 
الكثير للقراءة هناءولكن كلما أضفت فورم جديد للمشروع تأكد من إلقاء نظرة على كودها لتصبح على إطلاع بعملها الداخلي. 
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إن إعادة تعريف معامل أداة مفيدةء وأنا مولع خاصة بإعادة تعريف٠‏ م۷١٥‏ .لنعمل على إضافة إعادة تعريف عمرآ) إلى الفثة 1022ءا التي صممناها في 
الفصل التامن. :تعر ض هذه الفئة كل من الخاصيات ا×٠‏ ۲٠ء‏ آوة†ة2 ”ءt!‏ موفرة إمكانية الوصول إلى السمات النصية اعں†×عاوالعددية ٤ن١‏ لمحتوى 
الفئة.وإن هدفها الرئيسي دعم تتبع أرقام 0[في أدوات الصندوق المركب وصندوق القائمة.إذا كنا بحاجة لمعرفة رقم 10لبند مختار في أداة صندوق قائمة(لنسمه 
ئا مصS0m).فإننا‏ نستخدم کود مشابه للتالي: 

Dim recordID As Integer = CType(SomelList.SelectedItem, ListitemData).ItemData 
لايوجد شيء خاطئ في هذا الكود.ولكن إني أعتقد."أليس من الجميل تحويل حالة إلى انتفر باستخدام الدالة٤١1٥ .وليس علينا التورط بمتغيرات عضو مثل‎ 
"¢ ItemData 

Dim recordID As Integer = CInt(CType(SomelList.SelectedItem, ListlftemData)) 


الكود غير مختلف.ولكن لدعم هذا التحويلءنحتاج إلى إضافة إعادة تعريف ءمرآ إلى فئة 03٤2‏ !اء أا.افتح ملف تلك الفثة .وأضف الكود التالي كعضو للفئة. 
Public Shared Widening Operator CType (ByVal sourcelItem As ListItemData) As Integer‏ 


للتجوبل إل اتتغر رتتساطة استجرج عنصر اتشر 
Return sourceltem. [temData‏ 
End Operator‏ 


هذا بسيط جدآءهذا التحويل الموسع من هأة2 !ا1ء إلى انتفر يعمل على إعادة قسم الانتفر من الحالة.يوجد حوالي أربع أو خمس أمكنة في مشروع المكتبة الحالي 
بإمكانها الوصول مباشرة إلى العضوهاة |٠.١0‏ .وهي ليست بتلك الأهمية للعودة وتغيرها.ولكن سنستخدم إعادة تعريف التحويل بشكل متكرر في الكود الجديد 
المضاف في هذا الفصل. 


نحتاج إلى إضافة العديد من المتغيرات والروتينات الشاملة لدعم الميزات المتنوعة المستخدمة على طول التطبيق.سوف يتتبع متغيران شاملان الإعدادات المخزنة في 
جدول عمںاه۷”ءtءرS‏ لقاعدة البيانات.أضفهم كأعضاء إلى الوحدة البرمجية اaإeمGen)ذي‏ bؤv (General.‏ 
Public DefaultItemLocation As Integer‏ 
Public SearchMatchLimit As Integer‏ 


يطابق برنامج المكتية الكتب والبنود الأخرى كما تم تخزينها في المواضع المتعددة متل التشعبات(الفر وع) المتعددة أو مساحات التخزین.یıشير DefaultlteLocati0¬‏ 
إلى أي واحد من هذه المواضعءمن جدول ١‏ هماهم لهC‏ »وهو الافتراضي.تخزن مدخلة 0۸اه ااه ه0لجدول قاعدة البيانات ueاة۷ءtءرS‏ هذه القيمة بشكل 
دائم.عند البحث عن كتب.مؤلفين» أو أشياء أخرى يمكن أن تنتج آلاف المتطابقات»يدل† 5٠2٣١۸۸۷2٣1-1‏ على العدد الأكبر من المطابقات المعادة بعمليات بحث مثل 
هذه.ویتم تخز ينها كقيم نظام محددة |لبحڻSearchLimit‏ . 

بما أننا حالياً في الوحدة البر مجيةاة١6۲٠٠6‏ . أضف دالتي مساعدة إضافيتين: 


Pub ITE EUnEEIONn CONEITMDEEAULELOCAEA OR (J AS Eoolean 

0 اة نوات ادا جاه الوفع الافراض. 
DIT MSCAEIORID AS SEEING‏ 

1 ال لے ا ا اد عا ااا 


TF (Default lItemLocation = 1) Then 
locationID = GetSystemValue ("DefaultLocation") 
LE (lOocaltionlD = "") Then locationlD = 1-17 
DefaultItemLocation = CInt (locationlID) 
EAS UE 
NE ES BEN 1 
If (DefaultItemLocation = -1) Then 


MSTEOX E Sou MUSE iE detine Ehe dereulE EON LOCALISM, | 
MsgBoxStyle.OKOnly Or MsgBoxStyle.Exclamation, ProgramTitle) 
Return False 
Else 
REE UE True 
End lf 
ENA EUnCeEIOn 
Public Function GetcopyDisposition (ByVal copyID As Integer) As String 
ت‎ Gixen the ID Gf an 1ltem COPY, FEEUEN Ills CULFEOeNE SEAlEUS. 
The available results are: 


آ 

New Item Copy HEEOE OE MISSED EECEOSEA 

Checked In Copy is checked in and available 
1 Checked Out Copy 1s ehecked Out By û Patron 
Overdue Copy is checked out and late 

1 Missing Copy has been reported missing 
Reference Copy is a reference COPY 


DIM Sql Text AS SEIN 

Dim dbInfo As SqlClient.SqlDataReader 

Dim response As String 

On Bro GOLO EEE OSEHaARNG LEE 

Retrieve information about the book.‏ کے کے ا 


Sa lexe > PSBEECTL ME Eeterencee, LC Missing, EC MIsS1ng AS BalEORMI SSI, GC 
BC. DueDate, EC EFaecron LROM TEemCoBpy AS TE MEET ION PalrOnCOPY AS BE FTE 
ONY UE OD 3 AC TESCO MENS CE ED SY CG COND € | 


" AND PC.Returned = 0" 
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False) Then 


False) Then 


TMEue) COE CBOSS True) Then 


Then 


Then 


True 


Return 


hing) Then Nothing 


ContirmDefaultLocation 
يتحقق هذا الروتين من وجود مدخلة الموضع الافتراضي ١٥'اةء ]انهه في الجدول مuاة۷”ءءرS.ويعمل على إرجاع صواب في حالة النجاح.‎ 
GetCopyDisposition 


يوفر هذا الروتين وصف قصير للحالة الحالية من نسخة بند مكتبة معين.إنه يحلل سجلات العميل والبند»ويعيد واحد من حالات نصوص الكود:نسخة بند جديد ع١‏ 
Reference gجرم)Jılڏ Î. Missingدgقo. Overdueتl İi. Checked Outٽlرëall. Checked Inتsaall Item Copy‏ (. 


ماذا يوجد في الاسم؟.حستاًء إذا كان اسم المؤلف ١١٥٣اناهفي‏ مشروع المكتبةءيمكن أن يتضمن الاسم الأول والاسم الأخير ئه”۳ه"٣‏ اها ۵٩۸ھ‏ ءا » السابقات 
prefixesمثل("د"‏ D)ولاحقات‏ e5×اuffءمثل("القروي").‏ وتواريخ اهل من أجل الميلاد والموت٣أةعل‏ ١ه‏ ٣اط‏ .يعض من هذه الأجزاء اختيارية .لذلك 
تنسيق اسم المؤلف عملية متعددة الخطوات.بما أن التطبيق سيحتاج إلى تنسيق أسماء المؤلفين في عدة أماكن على طول الكود»دعنا نضيف روتين مركزيء 
FormatAuthorName‏ والذي یقوم بهذا العمل. 

EUD Le ELNEEAON ByRef 


Mhm76 الفصل الثانى عشر :إعادة التعريف والامتدادات‎ 
LE (TODS (ElIMEOL OEY 3 MELOY EOD | 
auEhor Name G&G. FT CEC CEEEABIREON SUEES) 
٢ ج‎ Add in the birth and death years. 
TE (TSDENuULI CABIR O ER r ERYeaAE J) > Hae) OE | 
(IsDBNull (dbInfo!DeathYear) = False) Then 
authorName &= " (" 
If (IsDBNul1l (dbInfo!BirthYear) = True) Then 
authorName &= "?2?2?2?" 
Else 
authorName &= CStr (Math.Abs (CInt (dbInfo!BirthYear)) ) 
TE (CINE (ABINEONBIT ERYZeaAE) < O0) Then author Name «= BE 
ا‎ 
authorName &= "-" 
If (IsDBNull (dbInfo!DeathYear) = False) Then 
authorName &= CStr (Math.Abs (CInt (dbInfo!DeathYear)) ) 
If (ClInt (dbInfo!DeathYear) < 0) Then authorName &= "BC" 


ERO UE 
authorName &= ")" 
EN E 
١ سس‎ Finished. 


Return authorName 
End Eüuncetion 


هذا الروتين هو طريقة توسيع تعمل على تمديد الفئة 2ء 0a2 R‏ اient.SqاCاSq.تصنع‏ المواصفة 01ء × المؤهلة بالكامل الاتصال بين التوسع الخاص بنا 
وفئة إطار العمل المحددةاملةء ۸R‏ هام2 S|‏ . منج Reader‏ ataطاوS‏ المبنية من سجلات في جدول A٣٥١‏ ودالة التنسيق والعودة باسم المؤلف بشكل لائق في 


التنسيق " .(1900-1999) .٣ل ٣ Q,‏ hەل‏ ,عiاط۴u‏ ".في مكان أخر من التطبيقءيتم استدعاء هذا الروتين وكأنه عضو من حالة قارئ بيانات: 
dbInfo.FormatAuthorName ( )‏ 


نستطبع أن نهمل ميز ات طريقة التمديد بالكامل بحذف مواصفة التمديد #أاطأ٣أاة‏ هاو ها×ع بكل بساطة.ومن ثم»سييدو استدعاء تنسيق المؤلف كالتالي: 
FormatAuthorName (dbInfo)‏ 


الآن بدأت الأشياء بالوتوب.سنعمل على إضافة 23فورم إلى التطبيق في هذا الفصل.معظمها تنفذ محر رات الكود القاعدي.مشابهة لملفات 776.۷6 50۲3ل و 
e. vb‏ u0NamدGr‏ التي بنيناها في الفصل 11. نماذج أخرى موجودة لتوفير دعم إضافي لمحررات السجلات هذه. 


فخ الاك لار الول عن المكة تنجد أعاة ركه لفات الى يمى غ اشا فاع الماات ك لذ مى الك ةةة شى 
authos.والناشرين۸6۲5ءااطاام‏ . من المحتمل أنك تتذكر أن النموذج كل١۲هء‏ ٠18ل‏ ع1ءناالشامل يعرض جمبع السجلات الموجودة من سجلات جدول بشكل 

افتر اضي.وهذا يعمل بشكل جيد من أجل مجموعات الاأمن كماتاو رااuعهء‏ المخزنة في جدول ه2۳١‏ مهما أنه ومن المحتمل ليس لديك الكثير منها.ولكن 
کیا و ا کی و اک و اوا ی وة ا ا یآ ا ای اف 


ضمن القائمة. 
تساعد النماذج الأربع"تحديد-البحث"على تخفيض عدد السجلات التي تظهر في القائمة في الحال.عندما يتمكن أمين المكتبة ١۵٣۲۵طذامن‏ الوصول إلى قائمة الكتب 
وبنود المكتبة الأخرىءفإن النموذج ١اصا"‏ 6)ايوفر حث(طلب)بحث سربع والذي المجدو E‏ 


ادخل مجيار الاختيار لجنوان البنداتستطح تضصين رمز النحدة""" 
تقبصة عاصة بدلا حرف 


8ا استخلاص جمبح البنود 


ا استخلاص بند بالعنوان 


تتيح هذه الفورم للمستخدم استخلاص جميع السجلات» أو بنود معينة بالاعتماد على اسم بند(مع دعم القيمة الشاملة).حالما يتم تحميل المتطابقات» يمكن للمستخدم الوصول 
إلى هذه الفورم مرةً أخرى بالنقر على "بحث مهه[ " على النموذج ءلإهء٠i1Rلعاءنامن‏ أجل هذه الأتواع من محررات الكود التي تدعم البحث 
عن(المؤلفين»بنود زبائن» والناشرين).نحن الآن جاهزين لتضمين نماذج تحديد البحث الأربعة في المشروع: 

AuthorLimit. vb 

تحدد الفورم سجلات المؤلف كما تم تحميلها من جدول |Jلمؤلd Author‏ . 

/temLimit.vb 

هذه هي الفورم التي تحدثنا عنها سابقاً.فهي تحدد عرض بنود المكتبة من جدول ٣#اكه٣2..‏ 

PatronLimit. vb 


الفصل الثاني عشر:إعادة التعريف والامتدادات Mhm76‏ 
في حال احتشاد الزبائن على مكتبتكءتتيح لك هذه الفورم تحديد السجلات المحملة من جدول الزبون ١ه٣اج۴.‏ 

PublisherLimit. vb 

تحدد ھذہ الفورم السجلات من جدول الناشرین ١۴٥۸ءااطں۴.‏ 


على الرغم من أن معظم محررات السجلات توفر تجربة تحرير كاملة من خلال الفورم 0118٠٥0۲١5‏ ع1ءناءبعضها خاضع لنماذج تحرير أخرى.فالكلمات المفتاحية 
Keywords‏ والمواضيع كأءعزطاءهي مثال جيد.حيث أن لكل منها جداوله الخاصة(الكلمة المفتاحية والموضوع])»اخترت السماح بتحريرها من خلال النموذج الذي 
يحرر بنود المكتية المستقلةء أي النموذج ۳ءا١ه‏ ٠ه"‏ (سنضيفه فيما بعد).تدير تلك الفورم جميع التفاعلات بين سجلات الموضوع والكلمة المفتاحية وجدول 
temاNNamed.‏ كل هذا من خلال الجداول الوسيطة temSubject وltem Keyword‏ لeلاقة‏ عدید إلى عدید.توفر |النموذج illgKeyword«Addمgڏج SubjectAdd‏ 
مدخلة نص بسيط من أجل كلمة مفتاحية أو موضوع.اعمل على تضمين كل هذه النماذج الآن في المشروع: 

.النموذج إضافة كلمة مفتاحية.vb ٠ Keywo0/rd۸4dQ.‏ 

.النموذج إضافة موضوع.60⁄. 1400ء ٠ Sube‏ 


كما سنرى فيما بعدءإن نموذج "ال٠2‏ واحد من النماذج الأكثر تعقيداً المضافة إلى مشروع المكتبة حتى الآن .فهو يدير كل شيء يخص بند مكتبة مولد(مثل كتاب 
ما).كل بند يمكن أن يكون لديه عدة نسخ.مؤلفين»كلمات مفتاحية.مواضبعء وهكذا.من أجل التحرير الفعال فمن البساطة تضمينها جميعا على نموذج مفرد.عملنا سابقاً على 
إضافة نموذجين تابعين(أو ثانويين): ل0۲44 سو 140dءهزطSu.دعنا‏ نعمل على إضافة خمس نماذج دعم إضافية. 

AuthorAddLocate. vb 

تثل هذه الفورم واجهة مشابهة لمعالج سحري يتيج للمستخدم إضافة سجل مؤلف جديد أو موجود لبند.والمؤلفين في برنامج المكتبة مصطلح شامل يشير إلى المؤلفين 
os‏ auth.المحررین0۲Sاdi‌ه‏ .المفسرین‌0۲5ه۲ءں اا¡ »الممتلین أو الفنانین‌؟۴۲١٠١٠6۲۴م‏ »وهكذاء خطوات المعالج السحري الثلات للنموذج تسمح 
للمستخدم(1)الإشارة إلى نوع المؤلف بواسطة جدول ممر١۲٥۸0ا2(.C046۸u)‏ عمل بحث عن مؤلف موجود بالاسم»و(3)اختيار أسماء مؤلفين من قائمة مطابقة.إذا لم 
يكن المؤلف المطلوب في قاعدة البيانات حتى الآنءتسمح الخطوة الأخيرة بإضافة مؤلف جديد.يبين الشكل التالي أو خطوتين من الخطوات الثلاث. 


إضافة آو إيجاد مؤلف أو أصم إضافة أو إيجاد مؤلف أو أسم 


إضانة أو إيجاد ملف أو اسم إضاخة أو لإيجاد مؤلف أو اصم 


استخدم هذا النصوذج ليايجاذ ملف أو اسم أخر لبند السكتبة استخدم شذا النموذج لإيجاد مؤلف أو اسم أخر ليند المكتبة 


ادخل مجيار الاختيار لاسم المؤلف تستطبح تضمين رمز النجمة"* كحرف حدذ نوع الاسم للإضافته إلى بند المكتبة هذا, 


فيصة شاملة يمكن ان تكون التائج مجذودة .الاسم الاخير صطلوب 
نوع الاسم: 


الأسم الاير 


انسح الأول 


يتم التحكم بمعظم المنطق من خلال معالج حدث زر التالي ٠×‏ .تشكيلة الكود في هذا الروتين تعتمد على لوحة المعالج الحالي التي هي قيد العرض(كما تم الإشارة 
إليها من قبل المتفير ا6٣۴‏ الذي على مستوى الفئة ).إليك الكود الذي يعمل عندما ينقر المستخدم على زر التالي بعد اختيار نوع المؤلف همر autho‏ : 
If (CInt (CType (NameType.SelectedItem, ListltemData)) = -1) Then‏ 
MEV Se (USL GS Ml CD ll ML SOO SE ME OOM O‏ 
MsgBoxStyle.Exclamation, ProgramTitle)‏ 
NameType. Focus ()‏ 


Return 
ENO TE 
' ات‎ 0 ON 
ActivePanel = PanelCriteria 


SecondPanel.Visible = True 
FirstPanel.Visible = False 
ActBack.Enabled = True 
LastName. Focus () 


ألا ترى سطر المنطق الأول في ذلك الكود؟إننا نستخدم دالة التحويل ٤٣ا٤‏ للحصول على قيمة ه0 #اامن بند قائمة.وهو استدعاء لمعامل #مر٣٥‏ الذي عملنا على 
إعادة تعريفه في فئة هأة 0" ه)اااا. 

PublisherAddLocalte. vb 

تشبه هذه الفورم تماماً الفورم السابقةء ولكن تركز على الناشرين.ومعالجها السحري لديه خطوتين فقط بما ان الناشرين غير مجمعين بواسطة النوع# ملا .إنها تعمل 
على إيجاد أو إضافة سجلات في جدول الناشر١٠٣ءااطد۴‏ .عندما يحين الوقت لاإضافة ناشر إلى بند ماءيستدعي فورم محرر البند الدالة 

Add Locate.PromptUser‏ isherاub.وتعود‏ هذه الدالة بالمعرف ۱0 لسجل الناشر المختار» أو -1 لإجهاض إضافة ناشر.القيمة الراجعة-2 تعمل على تنظيف أي 
اختیار سابق. 

SeriesAdaLocate. vb 

تشابه هذه الفورم الفور 26٥٥۔۵‏ ۸۵۲۸ءااطا۴u‏ .ولکن تنیتق من أجل السجلات من جدول 5 .C٥deSe‏ 

/ItemAuthorEdit. vb 
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حالما يتم إضافة مؤلف إلى بند ماءالطريقة الوحيدة لتغفيره إلى مؤلف مختلف هي إزالة المؤلف الفير صحبح»وإضافة المؤلف الصحيج بشكل منفصل من خلال الفورم 
Locate‏ AuthorAdd.ولکن‏ إذا اختار المستخدم ببساطة نوع مؤلف خطأ(مثل "محر ر ۲٥ا٤‏ " بدل "مفسر أو شار ح۲٥٣‏ †ءںاا| ")فمن العبء البحث مرةٌ أخرى 
عن اسم المؤلف لتفير النوع فقط .تتيح الفورم "۸u ۸٥۲۴١٤‏ 6االلمستخدم من تعديل نوع المؤلف المضاف سابقاً لبند ما.فهي تعدل حقل قاعدة البيانات 

.ltemAuthor.Author Type 

/temCopy. vb 

من المحتمل أن يكون لدى المكتية عدة نسخ من كتاب معين» أو سيدي»أو أي بند أخر.في مشروع المكتية.هذا يعني أن كل سجل "ال١‏ هل١يمكن‏ أن يكون لديه أكثر 
من سجل ل٥٥۵۸‏ ا|مرافق له .کل نسخة یتم تحریرها من خلال الفورم (شاهد الشكل التالي).__ 


متاح لللاعارة والإاعادة 


E 


شذة النسخة فقدث أو فاثعة 
تاخ الإعادة؛ 
١‏ الحالة الحامة: 


وضع بند؛ 


الموقج: 


على الرغم من أن هذا الكود غير مشتق من ٠۲۳١‏ ۴٠٠٥۵ء8‏ كما مع المحررات الأخرى.فهو ما يزال لديه العديد من ميزات تلك النماذج»من ضمنها الروتين 
ve۴ormDataهك‏ الذي يكتب السجلات إلى قاعدة البيانات. 

واحد من الأشياء المهمة التي تعملها هذه الفورم هو أن لديها دعم لقراءة الأكواد القابلة للقراءة من قبل الألة.تتصرف العديد من قار نات أكواد الألة كمقحم #وdكمس‏ 
إدخال نص كود الآلة للبحث ضمن جدول إدخال لوحة مفاتيج 2۳٠١ء‏ اام" ١ام0طرeء‏ الكمبيوتر.فأي برنامج يعرض كود الآلة عليه عرض إدخال نص طبيعي. 
ماسحات حشر أكواد الآلة تزييل(أو تعمل على إلحاق) عودة المشيرة(المفتاح إنتر 8۴٤١ع‏ )إلى نهاية أكواد الآلة المنقولة.يسمج هذا للبرنامج من اكتشاف نهاية رقم كود 
الآلة.ولكن في معظم نماذج برنامج المكتبةء المفتاح انتر 6١‏ يعمل على إطلاق الزر "موافق 0۸ " ويغلق الفورم.نحن لا نريد أن يحدث هذا هنا.لمنع هذاءستنعمل 
على إضافة بعض الكود لهذه الفورم ليعمل على تعطيل النقر الآلي على الزر "موافق 0۸ " كلما كانت نقطة الإدخال في حقل إدخال نص كود الآلة. 


Eri va lê SUS ReCOEJESAECOdE HRESr (BYVal Sendes AS OBNlECE, BVI € AS SVEN EVEREAE OS) 
Handles RecordBarcode.Enter 
2 کل اام‎ 
RecordBarcode.SelectAl1l () 
1 لاتسمح اكار وا عدو او رح‎ 
Me.AcceptButton = Nothing 
ERG Sub 
EVIE SUS RECO CIEE OOS Eee _| 
Eval Sender AS Ob lecte, EVLA E AS SVMS EEME EVEN EAS 
Handles RecordBarcode. Leave 
ا ا اح ره اا ا‎ 
Me.AcceptButton = ActOK 
ERA SUB 
Eri vate SUD ReCOEJBAEEOdE HeVEEEeSS (BYVUSN sender AS OONECE, | 
ByVal € AS SyStTeM . WINAOWS - EOEMS ‘KeYVEEESSEVENEAEOIS) 
Handles RecordBarcode.KeyPress 
' جاهل مقتاج انار‎ 
Tf (e.KeyChar = ChrW (Keys.Return) ) Then e.Handled = True 
ERA SUB 


مع هذا الكود »عندما يضغفط المستخدم على المفتاح انتر في حقل كود الألة بشكل يدوي.فإن الفورم لن يتم إغلاقها.ولكنه ثمن بسيط تدفعه من أجل دعم كود الأآلة. 


2 من النماذج المضافة في هذا الفصل تشتق مباشرة من فئة الفور ٥0۵٠۴٠١۲٣١,‏ ه8 .أضفها إلى المشروع كما سأراجع كل منها: 

Author. vb 

يحدث نموذج المؤلف ۲٥٣ا‏ 4السجلات في جدول قاعدة البيانات۲ه۸ں۸ .وكفئة مشتقة من الفورم, ٥٠۵6۴١۲٣‏ 8:ه8B‏ .فإنها تعمل على إعادة قيادة العديد من العناصر 
العامة لفنتها القاعدية.اثنان من إعادة القيادة لم نعمل على استخدامهما من قبل في الفصول السابقة وهما الطريقö‏ UsesSearchو‏ SearchForRecord.تسمجچ‏ ھذo‏ 
الطرق لمستخدم نموذج ل۲٥٠‏ ٠118ءا‏ تحديد المؤلفين المعروضين من خلال انيثاق النموذج ان ااه ان4 الذي تم شرحه سابقاً في هذا الفصل.(إعادة قيادة 
ListWith Records‏ يدعي أيضا earcnForRecordكللطاب‏ من المستخدم من أجل القائمة الأولية من المؤلفين لكي يتم عرضها).في 

." يعمل على إرجاع نص مفصول بفواصل في تنسيق" الأخيراكھ ا .الأولا|۴‎ Author imit.Promnp†لse٣ استدعاء إلى الطريقة‎ Search For Limit 
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الطلكت من المستخدم E‏ اسم ا 
exceededMatches = Fals‏ 
userLimit = (New AuthorLlLimit) .PromptUser ()‏ 
If (userLimit = "") Then Return‏ 
يمكن للمستخدم تضمين رمز النجمة(*) كقيمة شاملة 41۲۵| سفي بداية أو نهاية أجزاء الاسم.لقد أصيحت علامة النجمة حرف عام للاستخدام في جميع أنواع بحث 
القيمة الشاملة 4۵اس .لسوء الحظإنها غير مدعومة في عبارات السكول سيرفر "اختر 5851٤٥7‏ ".يستخدم السكول سرفر رمز النسبة المثوية(%) من أجل 
القيمة الشاملة (كما تعمل العديد من منصات قاعدة البيانات الخاضعة لسکول)بما أن ٤ا۲٥ 2٣۸۴‏ ه5يستخرج الأسم الأول والآأخير»فهو يضمن استخدام حرف شامل 
مناسب. 
ا ا ا ا في تحضير اال ا 
Tima t lase — LEIM(GeE ESUDSEE (User EMAC, CT)‏ 
AMIE EIESE = IEIM(GEESUBS EE (USeE MIE, CN , 20)‏ 
TE AMTELaSE & limi lEHit SE) LID) Ten RelUrn‏ 
TE ERSEE LM ELA SE, E) U TED ELSE GG‏ 
TE ERNSEE OM EELMESE, LD = OD ThE LONI ERIESE &‏ 
TEM ELaSE > Replace NLIMI ELAS, O, TE‏ 
EMI EEITSE < ROSIACE LIMIT ECELE, a, O)‏ 
هذا الكود يستخدم روتيننا الخاص ١5طں۲5ه6‏ الذي أضفناه سابقاً إلى الوحدة البرمجية ١١۲٠٣٠6.حالما‏ يتم استخراج أجزاء الاسم.تعمل دالة الفيجوال بيسك 
Replace‏ على استبدال جمیع نسخ * ب %.ستجد كود مشابه في محررات السجلات الأخرى التي تسمح بتحديدات على قائمة السجلات.مثل نموذج المؤلف 
isherاPub‏ الذي سنضیفه فیما بعد 
بينما يكون الكود المصدري لهذه الفورم مفتوح انتقل للأعلى.ستجد هناك عبارة ءا٣هم |٣‏ الهامة. 
EMOOE ES MUS 7 MIGEOSOI E UI SUSAN BASIC‏ 
عادة تكون عبارة كا۲مم"امتبوعة مياشرةً بفضاء أسماء.هذا التنوع يتضمن السابقة= ۷8( «والتي تعرف مختصر lلفضlء ùe Microsoft.VisualBasic slaw‏ 
أجل الكود في هذا الملف.مع إحضار الفيجوال بيسك العديد من فضاءات الأسماء ضمن فئة موجودة تعرف أيضاً الكثير من الأعضاء العامةءيوجد حصر(تقبيد)لأن 
تحصل تضاربات في اسم عضوفي هذه الحالة, التضارب هو عضو الفورم ۴٠ا‏ أو ١١۸16.بما‏ أن هذا الكود المصدري لنموذج المؤلف ١٥٣اا۸يرى‏ كل شيء من 
خلال منشور تلك الفورم» عندما تضمن الكلمة المحجوزة ٣#افي‏ منطقك.فإن الكود عادة يفترض أنك تعني خاصية الفورم6ا .والتي تعمل على وضع الموقع 
اليساري للفورء.المشكلة أن ۴٠ا‏ هي دالة معالجة نصوص مشتركة تستخرج حروف الجهة اليسارية من سلسلة حرفية أكبر. 
smallerString = Left (largerString, 5)‏ 
في نموذج ماءهذا الكود يولد خطأً يما أن الاعتقاد أن المقصود منه ٨۷16.16۴‏ لاستخدام نسخة السلسلة الحرفية ل ۲٠اءعليك‏ اسباقها بفضاء أسمائها. 
Smal leEFSEEIRNSG  MICEOSOEC.VISUAILBASTLE. LeRL ( UAEOCESLEIMNI, ©)‏ 
تتيح لك عيارة كاامم.|الخاصة استخدام اسم أقصر بديل من فضاء الاسماء عاج ua|8ء۷i.ا؟soهMicr‏ الطويل نوعاً ما. 
SMa I LEE SEE IRO MVS LEE E (LAETEESE ETO, ©)‏ 


ستجد عدة حالات مشابه لهذا الكود في نماذج أخرى تتضمن الاختصار ۷8. 
نموذج المؤلف لديها عنصر أكثر أهمية.تظهر لصاقة مطابقة الاسم 5ه٠ءأة۷‏ ٠4۳ل‏ قرب الحافة السظلية للفورم.كما هو مبين في الشكل التالي: 


E O RT EEE 


يساعد هذا الحقل المستخدم على تجنب إضافة نفس المؤلف إلى قاعدة البیانات مرتین.فعندما يتم عمل تفيرات على حقول الاسم الاخير والأولءیطابق الاسم حقل یتم 
تحديته بأسماء المؤلفين المتطابقة الموجودة في جدول المؤلف A٣٠١۲‏ .يحصي الروتين كا0ط† Refresh atc ہوA u‏ عدد المؤلفين المتطابقة من خلال الكود التالي: 
sqlText = "SELECT COUNT (*) AS TheCount " & "FROM Author WHERE LastName LIKE " &‏ 
DBText (Trim (RecordLastName . Text) )‏ 
TE (TEIMURECSEIETrESEName, exe) <> I) Then‏ 
sqlText &= " AND FirstName LIKE " & DBText (MVB.Left (Trim (RecordFirstName.Text), 1) & "%")‏ 
ل 
matchCount = CInt (ExecuteSQLReturn (sqlText) )‏ 
وهذا مشابه لكود البحث في الروتين ٥۲1-1٣‏ ۸۴١٣ه‏ ه5 .ولكنه يضيف فقط قيمة شاملة ٥4۲١‏ ١|أسإلى‏ الاسم الأول قبل عمل البحث. 
CodeAuthorT ype. vb‏ 
تحرر هذه الفورم السجلات المتعلقة بجدJa .CodeAuthorType‏ 
CodeCopyStatus. vb‏ 
تحرر هذه الفورم السجلات في جدول قاعدة Jlبlilٽ .CodeCopyStatus‏ 
CodeLocation.vb‏ 
كما هو متوقعءتحرر هذ الفورم السجلات في جدول ۸٥ااةءها٠ه١ه٥.حالما‏ تعمل على إضافة سجل واحد على الأقل على ذلك الجدول.ستكون قادر على وضع 
الموضع الافتر اضي لقاعدة البيانات.سأناقشه مرةً أخرى فيما بعد في هذا الفصل. 
CodeMedia Type. vb‏ 
تحرر هذه الفورم السجلات في الجدول همر ل6۷١٥‏ .متضمنة القليل من السجلات الإضافية أكثر من محررات جداول الكوده ١ه‏ .معظم الحقول تقيل إدخال 
عددي» على الرغم من أنني أعمل تفحص نهائي من أجل البيانات العددية المحققة(أو الصحيحة) تماما قبل كتابة سجل إلى قاعدة البيانات» أحاول من أي بيانات غير 
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عددية من الظهور في الموضع الاول وذلك بتقيد ضربات المفاتيح المقبولة.على سبيل المتالءحدث ضغط مفتاح حقل نص RecordCheckoutDays text field’‏ 
ress‏ KeyPيتضمن‏ الکود التالي: 
السماح للأرقام و التاك ستدس فط 
If (e.KeyChar = vbBack) Or (sNumeric (e.KeyChar) ) Then Return‏ 
e.Handled = True‏ 
وضع الخاصية ١ءال ٠.١٣‏ إلى صواب ٠د٣٣يوقف‏ الفيجوال بيسك عن عمل أي شيء آخر مع المقتاح انتر.إنها طريقة سهلة وسريعة للتخلص من المفاتيح المدخاة 
من قبل المستخدم. 
CodePatronGroup. vb‏ 
تحرر هذه الفورم السجلات في .CodePatronGroup J>‏ 
CodeSeries. vb‏ 
هذا المحرر يدير السجلات في جدولءهاإهSههه٥‏ .ذكرت سابقاً كيف يتم إتياع الكلمات المفتاحية sك١0۲سرهءوأسماء‏ السلاسل ك#"۳ه"٣‏ ك ا٣ء‏ بنود مسماة 
"amd items‏ .ولكن كان من الواضح لي أيضاً توفير إدارة مياشرة لأسماء السلاسل.في حال أردت تركيب قائمة مشتركة قبل إضافة بنود مكنتبة مستقلة.لذلك.تعمل 
هذه الفورم واجبين مضاعفين:تستطبع الوصول لها کمحرر سجلات قیاسي من خلال الفورہ۲۵5٥٥‏ 1۵۸۲ءا »ويتم استخدامها أيضاً من أجل بند مسمى بعينه من 
خلال نموذج ۳ ءtاك١م‏ ٣هل‏ الفير مضافة حتى الان. 
عند تحرير أسماء سلسلة ليند معين»يعمل المستخدم أولاً بحث عن اسم السلسلة بكتابتها.بما أتني لا أريد من المستخدم إعادة كتابة اسم السلسلة مرةً أخرى في نموذج 
هذا المحرر.فأردت تمرير اسم السلسلة المكتوبة إلى نموذج كهنهSه١ه).ولكن‏ ولا واحد من الطرق المعاد قيادتها تدعم هذا.لذلك سنحتاج إلى إضافة طريقة جديدة 
تقبل الاسم المكتوب. العضو ۸44۸٠0۲١‏ الذي يعيد قيادة الدالة القاعدية لنفس الاسم . 
Public Overrides Function AddRecord() As Integer‏ 
إضافة سجل جديد ' 
ActiveIlD = -1‏ 
PrepareFormFields ()‏ 
Me. ShowDialog ()‏ 
UE (Me Di alogEesUlE > WInNIOWSs HONS Bal OGRE S ULE O) men‏ 
Return ActivelD Else Return -1‏ 
ERE EME E LOM‏ 
دعنا نضيف إعادة تعريف لهذه الدالة بحيث تتضمن معامل نسبي نصي.سيمرر المستدعي النص المكتوب الأصلي إلى هذا المعامل النسبي.سنعمل على إسناده إلى 
خاصية النص N 2e ةادالل٣ ٥×۲‏ اا۴ Recordبحيث‏ تظهر بشكل آلي عند فتح الفورم. 
Public Overloads Function AddRecord (ByVal seriesText As String) As Integer‏ 
ActiveIlD = -1‏ 
PrepareFormFields ()‏ 
RecordFul lIName. Text = seriesText‏ 
Me. ShowDialog ()‏ 
If (Me.DialogResult = Windows.Forms.DialogResult.OK) Then Return ActiveID Else Return -1‏ 
ERO EUnRGCLEI OM‏ 
كان بإمكاننا استخدام اسم ما بدل ١0۲٠۸44۸8لهذه‏ الدالة وتجنب إضافة إعادة التعريف0 0۷6۲|٥4‏ .ولكن من الجميل الحفاظ على الأشياء مستقرة(أو متطابقة). 
Holiday. vb‏ 
تدير هذه الفورم السجلات في جدول .فيما بعد في فصل لاحق سنعمل على إضافة مجموعة من العطل ضمن البرنامج من أجل سرعة الوصول. 
Patron. vb‏ 
نموذج الزبون توفر خدمات تحرير للسجلات في جدول الزبون١٠0١ه۴‏ ءوتظهر في الشكل التالي. ‏ 


ُ تحريو الزبون 


الاسم الخيرالأود: | 1 ا 
© التوجد أسماء متطابقة 


الفحاليات الأخيرة! غير متاح 


تاکیدها؛ 


.Ulse "NP" to clear the current password * 


تتضمن هذه الفورم أداة تبويب ٥0١٤٣0١‏ ۸٣للمساعدة‏ على تقسيم عدد الحقول التي م تجريبها في الحال.إذا كنت قد استخدمت أداة التبويب اها 
المضمنة مع الفيجوال بيسك6ءستقدر بسرعة استبدال الدوت نت.فهو يدير جمبع منطق تبديل اللوحات بشكل آلي عندما يختار المستخدم تبويب مختلف.كل لوحة هي 
حالة فئة لصفحة تبويب مو2 ۴طه٣منفصلة.في‏ كودك.إجبار أداة التبويب على عرض تبويب مختلف سهل كإسناد حالة صفحة تبويب ٠و4‏ 4۴٣مناسبة‏ إلى الخاصية 


.Validate Form Data ةöلlدJl .كما مچ سطر الکود من‎ rab Contr لانن‎ selected Tab 
TASEAL EON . SELECTS = TASCEONE TEL 
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على الرغم من أن هذه الفورم قد تبدو معقدة تماماًفهي مركية بالكامل من معظم الكود الذين رأيناه في النماذج الأخرى.خلف إعادة القيادة ÎعذlءBaseCodeForm‏ « 
تتضمن هذه الفورم دعم تفحص(أو مسج)كود التعريفه١هء‏ ١2ط‏ (كود تعريف الآلة على أداة ما) المستعارة من النموذجرمه٥١.٠!ا‏ »منطق كلمة السر ١285W0۲م‏ 
المسروقة من فورم 2۳٠‏ ١۲هءلاءوالكود‏ المطابق اسم مشابه إلى ماهو مستخدم في نموذج ۲٥طاAu.‏ 

عملت على تضمين زر إدارة بنود زبون ۴2٣0۸5 |٠5‏ مو2ة” على الفورم»ولكن لن نعمل على إضافة منطقه حتى فصل متأخر.وعند ذلك الوقت ستصيح 
الدالة العامة الإضافية ٩۲۵1ء Edi1۸‏ هامة في ذلك الوقت. 

Publisher. vb 

تتيح هذه الفورم للمستخدم تحرير سجلات جدول الناشر#۲ءأاطن۴ .وهي نموذج بسيط نسيياً م حقلي إدخال للبيانات فقط يشير حقل "الحالة usاهS‏ " إلى كيفية 
اتصال عدة سجلات"بند مسمى ١٠٠اال١6٣٠‏ ه١‏ " إلى هذا الناشر.يظهر زر صغير إلى اليسار من حقل إدخال النص من أجل موقع الناشر على الويب.وهذا الزر" أظهر 
موقع الويبط٥W۷۷٥S1‏ "وعند نقره»فإنه يظهر صفحة الويب الموفرة إلى المستعرض الافتراضي للمستخدم.لتمكين هذا الزرأضف الكود التالي على معالج حدث 


1 نقر زر "أظهر الويب".‎ 
EET SES EA EST EE OB 
Dim newProcess As ProcessStartInfo 
On Error Resume Next 
TE (TEIM(RECSEIWNES. TORE) . 1") Then RKeEUEN 
newProcess = New ProcessStartInfo (Trim (RecordWeb. Text) ) 
Process.Start (newProcess) 
SystemValue. vb 


يعالج محرر هذا الكود البنود في جدولعںاة۷"ء1ءرS‏ .على الرغم من أننا سنصله إلى وصلة على نموذج المكتبة الرئيسي في هذا الفصل»سنعمل على تغيير طريقة 
إمكانية الوصول في فصل لاحق. 
حسناًءهذه 11 فورم من 12 فورم مشتقة.الفورم الأخيرة هي الفورء١۲۳اك۸4”6‏ المبينة في الشكل التالي. __ 


| تجوير بنډ محرد 


| غير معنون 


مجرف قاعدة البيانات! غير متاح 
عنوان البند الرثيسي : 
عنوانا البند الفرعى:؛ 

الوهيف : 


إن الفورم ١۳٠االه‏ ٣هي‏ الفورم الأكبر والأكثر تعقيداً من بين النماذج المشتقة من النموذج 0006۴٠١۲٣١‏ ه8 .فهي تحرر بنود المكنبة الرئيسية المسجلة في 
جدول قاعدة البيانات "٠ء‏ ال١ه‏ .وهي معقدة لأنها تدير بشكل مياشر أو غير مياشر السجلات في جداول تابعة (أو تlنوية‏ (Îخرé: «temCopy «ltemAuthor‏ 
.Subject g «Publisher «Keyword «Author :Jglجll lı رıغ Jy ItemSubject «ltemKeyword‏ 
جمبع الحقول على التبويب "عام" وتبويبات التصنيف تعتمد على حقول المدخلات التي تتدفق مباشرة إلى جدول اله" .تماما كما تم عمله مع نماذج تحرير 
السجلات الاخری.تستخدم حقول السلاسل 8۲65 والناشر ۲٥۸ءناطں‏ ۴ نماذج اختیار منفآ¬صlة)‏ PublisherAddLocateو Locate‏ SeriesAdd)للحصول‏ على قیم 
المعرف 0 المخزنة في ۳ءاال١م‏ ٣ه"‏ إليك الكود الذي يبحث عن الناشر: 

ETE 


newPublisher = (New PublisherAddLocate) .PromptUser () 
If (newPublisher = -1) Then Return 
` اا ار اال الات‎ 
If (newPublisher = -2) Then 
RecordPublisher.Text = "Not Available" 
BUD SRE D = 
Return 
EMO UE 


التبوييات الاربع الباقية- jılall/اAuthors/Namessle‏ ءالمواضبعءاء هزان الكلمات المفتاحية؟ل0۲ »ره .والنسخ5ه امه -تدير السجلات الثانوية. 
الكود ثابت(أو متطابق) إلى حدما بين التبويبات الأربع.لذلك سوف سأقتصر في تعليقي على التبويب مؤلفين/أسماء(شاهد الشكل التالي). 
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المكلف أو الاسم 
اسم المؤلف 


Mhm76 


الأدوات على هذا التبويب مشابهة لتلك التي على النموذج ٥١١s‏ ٠10۸ء‏ ناءفهي موجودة لإدارة مجموعة من السجلات في جدول ما.في هذه الحالة.إنه الجدول 


۷6W أجل تقديم القائمةءسأختار استخدام الأداة "عرض القائمة سWها۷اءنا "بدلاً من أداة صندوق القائمة ×180ءاا القياسية.بوضع خاصية عرض‎ نم.اtem‎ Author 
لادا "عرض القائمة W٥۷iاءاا ' إلی 'تفاصیلءااھe٥ "ءبوضع حقلھا ٤٥اWSe٥۱۸ا۴uإلی صواب ں٣۲ وتعدیل مجمع اعمدتھا Ü۶٣٣ںاهC (شاھد الشکل‎ 
. multicolurقدمعألا آلتالي)تستطبع بسرعة تبديلها إلى صندوق قائمة ×0 طا متعدد‎ 


ColumnHeader Collection Editor 


ColautharNarme properties: 

EER E 

KESÎ 21 کڪ‎ 
DisplayIndex 0 

E Data 

{Applicationsettinı 


ا 


ColAuthorName 
GenerateMermber True 


Friend 


none) 
{none} 
اسح الصولف‎ 
Left 


Tag 
Design 
{Narme) 


Modifiers 
Misc 
Imagelndex 
Imagekey 
Text 


TextAlign 


Remoye 


0 
1 | ColautharameType 


Members: 


Add ا1‎ 


عندما تعمل على إضافة بند ما إلى هذه القائمةسيكون عليك أيضاً إضافة"بنود فرعيةك١٣#اأطناء‏ "ليكون ليظهر لديك كل شيء ولكن جميعها في العمود الأول. 


Dim newItem As Windows.Forms.ListViewlItem = AuthorsList.Items.Add ("John Smith") 
newItem.SubItems.Add("Illustrator") 


يعمل الزر "إضافة ١ل^"على‏ إظهار lلنموiجocate_اorAdd Auth‏ «بينما يعرض llلjر‏ "خl|ëصlت .ltemAuthorEdit aرgفll " Properties‏ 

قبل أن يتم إضافة أي سجل ثانوي»يجب أن يتواجد السجل"الأبا١٠۲هم‏ " في قاعدة البيانات.وهذا لأن السجلات"الأبناء ١١ا‏ " تتضمن رقم المعرف 0| لسجل 
الأب»وبدون سجل الآبء فلایوجد رقم معرف Dاالاب.‏ 

إذا نظرت على كل روتينات الزر "إضافة ۸۵٩‏ "على هذه الفورم»ستجد كود مشابه للتالي: 


TT EAT EE MOC 
If (ActivelD = -1) Then 
الاه عل اال‎ 
TE (MSE MSR N AEE N SON EE CSOD AUG U OA ASN ES OLE 
ا ا د ا‎ o E OE, MIGBOSSEVNE. YeSNO Or MSIE OUeSEIOM, 5 
ProgramTitle) <> MsgBoxResult.Yes) Then Return 
a TY E gE 
Tf (ValidateEFormData () = False) Then Return 
ui Sauce lormDaca ll 2 Else) UREN Kecuzn 
End WE 
إذا كان هذا سجل ٣ء٤الم ”هل١ جديد تماماً(1- = ۷۵10اA)فإن هذا الكود سيحفظه قبل السماح للمستخدم إضافة سجل تابع.أي بيانات غير صحيحة تمنع من أن يتم‎ 
نفس‎ ثدحی8aveFormData‎ وValidatِe۴٥r‎ "02a الفعليءوالاستدعاءات لكلا الروتينين‎ ۷aاiههء۴‎ ٠٥۲" 5ةa حفظ سجل سيتم التقاطها في الاستدعاء للروتين‎ 
سجل جديد على النموذج المستدعي.ولكن ماذا بخصوص إذا‎ ١0 الشيء عندما ينقر المستخدم على الزر "موافق 0۸ ".عادةيعمل هذا على إطلاق إعادة رقم معرف‎ 
ما تم استدعاء هه۲۳2٠ ۴٠۷ه8بواسطة إضافة مؤلف.ولكن بعدها نقر المستخدم الزر"إلغاء »٣ه "(والذي يعيد عادةً القيمة -1 ليشير على" أنه لم يتم إضافة‎ 
.؟Sمءءا0‎ 182۷٥٩4 سجل")؟لتجنب ذلك. تعمل الدالة aاة۲۳2٥۴٥a۷على وضع متغير على مستوى الفئة مسمى‎ 
SessionSaved = True 
على إعادة‎ ١4. يتم تنظيف هذه العلامة عندما يتم تح الفورم للمرة الأولىءولكن يتم وضعها إلى صواب نسبياً في أي وقت يتغير سجل ثانوي.تعمل النموذج صءال6‎ 
وتتفحص هذه العلامة قبل إعادة قيمة إلى النموذج المستدعي.‎ Edit Record وAd4Recمءك قيادة الدوال‎ 
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Mhm76 لفصل الثانى عشر :إعادة التعريف والامتدادات‎ 
If (Me.DialogResult = Windows.Forms.DialogResult.OK) Or (SessionSaved = True) Then Return 
ActivelD Else Return -1 


يوجد الكثير من الكود الهام في الفورم٣٠†اك١‏ 4۳" .سأترك لك تفحص كودها. 


إذا شفلت التطبيق الآن.لن ترى أي اختلاف على الإطلاق.ما نزال نحتاج إلى وصل جميع محررات السجلات إلى الفورم الرئيسي.جميعها ترتبط من خلال الأدوات 
امab lL‏ inkاعلى‏ لوحة الإدارة للفورم الرئيسي(١ ٣i‏ ١1۸٥١۴4).نحتاج‏ إلى إضافة 12 معالج حدث نقر الوصلات ١عءا٣‏ )”ذا للتمكن من الوصول إلى جمبع 
النماذج المتنوعة الجديدة.تقدم للأمام وأضفها الآن إلى الفئة الرئيسية. 
كل من معالجات حدث نا٥۸‏ ناعلى الأغلب صورة عن الأخرى»ماعدا القليل من أسماء حالة كائن هنا وهناك.إليك الكود الذي يعالج النقر على وصلة الناشر: 
Private Sub AdminLinkPublishers LinkClicked (ByVal sender As System.Object, ByVal e As‏ 
System, WI RAOMS. HOES. A RKLa Oe ILI RECT Ce dEVER EAEIS)‏ 
Handles AdminLinkPublishers.LinkClicked‏ 
li (OSCUL LEMELOE LIE (LISA IEC E. MENEGSEODLSRES = |‏ 
False) Then‏ 
MSTEOX (NS EAUE ROE zedMes sage, MSTEOxXS Evl e. OKOnI vy OE‏ 
MsgBoxStyle.Exclamation, ProgramTitle)‏ 
Be UEN‏ 
Ol U‏ 
ListEditRecords.ManageRecords (New Library.Publisher)‏ 
ListEditRecords = Nothing‏ 
End Sub‏ 


بعد عمل اختبار سربع للأمنءفإن الكود يستدعي نموذج كل١0٥‏ ٠101ا‏ القياسي»ممرراً حالة من محرر سجلاته ليتم استخدامها.ماتزال هناك وصلات غير فعالة 
على لوحة الادارة والتي سنعمل على تمكينها في فصول لاحقة. 


إن اليرنامج الآن جاهز للتشغيل مع جمبع الميزات الجديدة.بما أننا عملنا على إضافة الميزات الإداريةءعليك نقر الزر "تسجيل الدخول "اوها " في الزاوية العلوية 

اليسارية للفورم الرئيسية قبل أن تتمكن من الوصول إلى لوحة الإدارة وميز اتها.مالم تغيره.فإن اسم مستخدم تسجيل الدخول هو" ٣1١‏ 4ة "بدون الحاجة إلى كتابة 

كلمة المرور.على الرغم من أنك تستطيع الآن تشغيل البرنامج والوصول إلى محررات السجلات.لن تكون قادر على إضافة نسخة بند جديد #5Sأمهء |8۳١‏ حتى تضع 

الموضع الافتر اضي١٥|اةعه!‏ انهه .لوضع الموضع الافتراضي: 

1.أضف على الاأقل موضع واحد من خلال وصلة "المواضع ك١‏ 0ناةء هما "على لوحة الإدارة. 

2.احصل على رقم المعرف 0| لسجل ١٥ناةء‏ مامه هع الذي تريد أن يكون افتراضي. 

تستطبع استخدام ميز ات الا ستعلام لمنصة إدارة سكول سرفر السريعةress 5Q1 Server Management Studio Exp‏ للوصول إلى السجلات في هذا 

الجدول.إذا كانت هذه المرة الأولى التي تضيف فيها سجلات إلى جدول١هةءهاههه‏ ءفإن البند الأول سيكون له قيمة 0 الرقم المعرف .1 

3.ارجع إلى برنامج المكتبة»حرر جدول عuاة۷٣۳ءاءر8Sمن‏ خلال وصلة قيم النظام sمuاج۷‏ #۳اءرS‏ على لوحة الإدارة. 

4.أضف أو عدل قيمة نظام" ١0اةع ٥‏ ام0 ".وضع قيمتها إلى رقم المعرف 0| لسجل الموضع الافتراضي . 

بشکل بدیل. تستطيع تحديث سجل"الموضع الافتر اضي ۸٥٤٥۔٤‏ اه0 "في جدول قيم النظام ٥ں‏ ا۷2٠‏ ءرSمياشرة‏ باستخدام منصة إدارة سكول سرفر 

اudرıعخExpress SL Server Management Studio‏ .إذا كان المعرف 0اللموضع ٤21٥١‏ ٥|المستخدم‏ هو1ءاستخدم عبارة سكول هذه لعمل التغیر: 
Update (SystemValue)‏ 
SET ValueData = '1'‏ 

WHERE ValueName = 'DefaultLocation'" 


في فصل لاحق.سنعمل على إضافة طرق قربية من المستخدم لتحديث هذا الموضع الافتراضي. 
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القن اللات عفر الترمير افاي اتوم Mhm76‏ 

لغة التر میز القابلة للتو سح (Extensible Markup Language)XML‏ 
1هي محاولة لتنظيم البيانات في تركيب قابل للاستخدام من قبل الناس والبرمجيات»ءوقد راجت في السنين الأخيرة»ولكن جذورها قديمة جدا. فقد تم 
اشتقاقها من ا 96۷M(لغة‏ الترميز المعممة lاlئnعيارıڈLanguage Standard Generalized Markup‏ )وكذلك 1 ۲]M[(لغة‏ ترميز النصوص 
الفائقة(المدمجة( Hyper ext Markup Language‏ ) القريية منها و 1 586Mبدورها‏ أتت من Generalized Markup ةnمعaئ| jıمرتلا ةغل(6G M1‏ 
Language‏ )»و هي '"'لغة التوnيف metalan guage‏ (لغة تصف لغة أخرى) تم تصميمها بواسطة 8M[في‏ عام1960. 
تمثل أبجدية تقنيات معالجة البياناتءالابجدية التي لديها سبع محاور وء غريبة. 


اM×هي‏ لا شيء أكثر من تنسيق بيانات بحيث تكون قابلة للقراءة من قبل الإنسان وقابلة للقراء من قبل الآلة. هل جربت فتح مستند ميكروسوفت ورد بواسطة 
المفكرة؟شاهد الشكل التالي. على الرغم من أنك تستطيع عادة التحقق اه ومن النص الرئيسي للمستند»فمعظم ما تراه غير مفهوم(هراء).وهذا لأنه في تنسيق 
ثنائي خاص proprietary binary ۴٥۲1٣4٤‏ .وهو خاص yاھie†aامoاملأن»وبصراحةءليس‏ عليك حشر أصابعك فیه.وهذا ما عليه میکروسوفت ورد. وهو 
ٿنائي راه 1الانك تستطيع تخزين الكثير من المعلومات بشكل مناسب في مساحة صغيرة من القرص.بمثل هذا الملف»أستطيع أن أخزن بياناتي بأي طريقة 
أختارها.في الحقيقة أستطيع تدوين بياناتي طوعا أو کر ھاً]1ازم willy-‏ »ولیس علي الحصول على ترخيص من آي واحد٬لآنها‏ تخصني»جميعها لي .(يبین الشكل 
اا و و ا کک 


ملف تحریر اسيق عرض تعلیمات 
خدةا. ± ال > 0ے 1 1 : 

„O6 U U UU: Gl Gliğ Jl 
lS 0O1 1 1 
- J" OEMJl2ODICI HTML (DIMI 10n eralized Markup Lan gua gel) HIclo 
IM IDI1UCIDN IDIATIDNN. 901 GN, IDNAN' O ZNM(O DIENANCIIN’ KOVOHI'IS3N) /OHN1 N* 
aK Uh oرا علق 1 1 ”مث"٣.ثم# نا ار‎ le ک1‎ l- ° TF J, 0| Bl DO x A I> U: ON ON 
@ > J0 ڈص و ب ن ةر ال‎ 4L1 8 ٦ ا ® چ یک‎ 


:Telh xvxgWgHH9x, ¢ Yiaê ¬ & - dG "r HF j 1 TI, LN XI Z1 fl hI ~0 | ãl 
2prietary because, frankly, you shouldnlt be poking your 


TFFLIê LFI 15S !ê! ê ن! و!‎ !a! جا ا دا زر ش! ض! طا ع! ا ف! ھڅ‎ 
I $M, 1, laTl= gdw}, m$lls &P "@ "4 "s> "! "A "" "£ 
OT*O 2)45, |1 ° OVS OVS#O°V"OA!T74° .,° ,{hlipw 

¬ O1 O1 O1 û" O1 O1 O1 û" û1 Û1 O1 O1 O" O" 


ف ف 


اھ 
الملفات الثنائية وع]ا؟ inary‏ Bعظیيمة‏ من أجل تخزین أي نوع من البيانات: :أعداد»سلاسل حرفية»صور مشفرة»جداول من الشبكات»أي شيء. لمل هي :اذا 
لم تعلم التركيب الدقيق الذي استخدمته لتدوينهاءفهناك دائما فرصة قلبلة في استعادة البيانات.وهذا جيد إذا كان هدفك السريةرعمإءعء »ولكن إذا احتجت إلى 
مشاركة البيانات اتا مخ أشخاص أو برامج أخرى»أو حتى أسوءءتصحيح مخرجات من برنامج منحرف»فإنك في مأزق.فاذا ما تم فقد بایت RT‏ 
المحتمل أن يصبح كامل الملف غير مفيد. 
بالطبع يوجد طرق أخرى لتخزين بياناتك.من أجل الملفات التي تخزن سجلات بيانات»توفر ملفات محدد الجدولة ل مص 1اءل-طاه† (محدد تنظيم الجدولة) و 
۷ (القيمة المفصولة بفاصلةعں ]ه۷ 4ء2۲21 مءء-2هء )وسيلة نقل مريحة(مناسبة)ءفي تنسيق أكثر ودا للإنسان. على سبيل المثال»خذ هذه البيانات من 
عينة قاعدة بيانات میكروسوفت التجارية''نورٹویند Ww 1Û‏ ط٤إہN‏ 'ءفقد تم تخزینھا كقيم مفصولة بفاصvaluesl comma-separated‏ . 
ProductID,ProductName,SupplierlD,Category, UnitPrice, Available‏ 
"1"«“"Chai","652","Beverages","$18.00","Yes"‏ 
"2"«“"Chang","9874","Beverages","$19.00","No"‏ 
"3"«"Aniseed Syrup","9874","Condiments","On Sale","Yes"‏ 
الآن هذا أفضل .هذه البيانات سهلة الفهم نوعا ماكل قطعة من البيانات تم تجميعها بواسطة فواصلءوالصف الأول يشير إلى ما يحتويه كل عمود.والجزء 
الأفضل أن العديد من البرامج تعرف سابقا كيف تقرأً ملفات في هذا التنسيق.إذا حفظت هذه البيانات في ملف نصي بالامتداد «وء. »وفتحتها باستخدام 
ميكروسوفت اكسل»فإن البيانات ستظهر بشكل آلي في أعمدة. 
ولكن يمكن أن تكون أفضل. على سبيل المتال»إلى ما تشير هذه القيم "652" و"9874" وبأي طريقة؟و هل صحيح أن سعر الوحدة ل pںإر؟‏ dمعءزم۸‏ هي 
"برسم البیع 821e‏ و0 "؟ 1 
بالتأكيد استطیع تحمیل هذه البيانات في برنامجي»ولكن هل استطيع فعل أي شيء بها؟على الأقل هي سهلة القراءة لكل من الإنسان وبرامج الکمبیوتر›و آلیں 
هذا ما قلته حول XML‏ ؟ 
حسناء على الرغم من أن ۷1 ×تتضمن قواعد وميزات تجعلها أكثر مرونة من ملف بيانات نصي عادي»وهذا ليس هو الفرق. من أجل جميع المبالغاتءفإن 
× هي مجرد طريقة في تخزين البيانات.أي سمة ل تم مناقشتها في هذا الفصل يمكن أن يتم إنجازها بسهولة بواسطة البيانات المخزنة في نص 
أبسط simpler text‏ أو تنسیقات خاصة iliîيformats binary proprietary‏ .في الحقيقة»على الأغلب من الأسر ع وأكثر راحة للتطوير استخدام تنسيق 
خlص proprietary‏ »لأن بياناتك ستحتوي على ما تحتاجه فقط وبدقة »دون أي خطأ. 


يتضمن كل عنصر نوع بيانات عنوان»والعناوين الجيدة تجعل القراءة جيدة. 


قن الت عفر هة ارم الفا اترم Mhm76‏ 
جميع البيانات تتضمن وسم بداية ونهايةءلذلك يمكن للبرنامج أن يعالج البيانات دون الكثير من الجهد.وعنصر واحد سيء لن يعمل بالضرورة على إتلاف ٣إا‏ 
كامل الملف. 


تستطيع تخزين أي نوع من البيانات في M1‏ ×. بالنتيجة فهو مجرد ملف نصي.إذا كان لديك تنسيق ملف _™×معين مستخدم في النسخة رقم1 من 
برنامجك»وأضفت ميزات له في النسخة رقم2ءتستطيع عمله بطريقة بحيث يبقى متاح لبرامج النسخة1 استخدام ملفات النسخة2 بدون خرق. 


تتضمن ۷N‏ ×العدید من الميزات والتي تتیح لك وصف محتوی XML‏ . الأكثر شیو عا اثنان هما 51۲[ (تعریف نوع المستند Document Type‏ 
(Definition‏ وX×SD‏ (تعريف تصميم بياناٿٽXMI Schema Definition)‏ ا[XM1‏ )).إنك تستخدم هذه الأدوات للإشارة إلى ما تتوقع أن يحويه بالضبط 
ملف بياناتك.بالإضافة لذلك»تسمح لك تضمين تعليقات في المحتوى دون التأثير على البيانات الفعلية. 


الأدوات المتاحة من ضمنها الأدوات في الدوت نتءوالتي تستطيع التشديد على تكامل وتنسيق ملف ۷M‏ ×بمقارنة المحتوى د 015ر $5 المصاحب 
.وهذا يتيح لك التحقق من ملف قبل حتى معالجته. 


لقد حصلت N1‏ ×على قبول واسع الانتشار ءا widespr e4 accep‏ «حتى عبر منصات الکمبيوتر llئnتشعبplatforns divergent computer‏ . 
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يحتوي محتوى _[۷N×على‏ الكثير من المعلومات التركيبية المتكررة»وبشكل عام الكثير من الفراغات البيضاء.تستطيع اختصار ع۷1 عط طھالعدید من 
عناصر التركيب»و إزالة جميع المساحة البيضاءعءهمءعاطس (لا تحتاجها -1١)))»ولكن‏ هذا سيزيل سمات قابلية القراءة بالنسبة للإنسان من البيانات.بعض 
منصات العملءمرإ0؟ اهم » مثل مستعرضات الهواتف الخلويةإعءس0إط ٥«0طم‏ 11ءءءتحب الاحتفاظ بالبيانات صغيرة. ۷1 ×هي أي شيء ولكن صغيرة. 


انتظر هذا شيء جيد في معظم الأوقات.بعض الأحيان تريد تخزين بيانات ثنائيةرإهم1ط فقطمثل الصور. في الواقع لاتستطيع تخزين بيانات ثنائية حقيقية في 
ملف ۷ ×دون كسر واحد من القواعد الأساسية ل ۷1× تقريباً:نصوص فقط !على الأغلب»البيانات الثنائية يتم تشفير ها في تنسيق يشبه النص»متل القاعدة- 
64(والتي تستخدم الحروف القابلة للقراءة لتخزين البيانات الثنائية) 


| 


وهذا يأتي من كون لديها بيانات في تنسيق شبه قابل للقراءة من قبل الإنسان كثير الحشو(مسهب)ءبدلا من المصقول(الوجيز)»وضغط النموذج الثنائي.ببساطة 
تستغرق وقت أطول بالنسبة للكمبيوتر لعمل مسح نص في البحث عن الأقواس المحدبة المتطابقة من عمل نقل عدة بايتات مباشرة من كتلة بيانات ثنائية ضمن 
موقع في الذاكرة. 


لايوجد الكثير من الأسرار في ملف M1]‏ ×.على الرغم من أنك تستطيع تشفير عناصر البيانات في الملف»أو كامل الملف لسبب ماءهذا سيؤدي نوعا ما إلى 
إحباط الهدف من استخدام .×M1‏ 


1آ ليست مناسبة لكل نوع ملف بيانات. 


كما أكرر٬ءإن XML‏ مجرد ملف نصي.فهي ليست الدواء العام»مجرد تنسيق ملف مفيد. 


قبل أن نلقي نظرة على ۷1× الحقيقيءتحتاج إلى معرفة المبدأً.عليك أن تطيع رم طهالقاعدة في كل قطعة من نص ۷N‏ ×الذي تكتبه. 


إذا لم تستخدم 1× ءولکن قد کتبت بعض 1۲1 ءفإن ما أكتبه سيكون معروف نوعا ما. 


هذه هي لاتنسها.أطعها.وسأشرح ما تعني فيما بعد. 


إليك قطعة من 11× لتستمع بها. 
<?xml version="1.0"?2>‏ 
<hello>‏ 
<there>‏ 
E Hinav, real QaAEd Meke. >‏ 
<world target="everyone">think XML</world>‏ 
EOE 23I GOUNE G94. S4 EOE ECON‏ 
<goodbye />‏ 


الفص الثالث عشر:لغة الترميز القابلة للتوسع. Mhm76‏ 
<Jtherez‏ 
me‏ 


وهذا واضح من السطر الأولءوالذي دائما يبدأ ب...١‏ »?> »هذا السطر يشير أيضا إلى رقم نسخة 01 »ءوالتي تخبر روتين معالجة ا×(المعربات 
‰6 مم )لضبط السلوك عند الحاجة. 


إن ا ×هو تركيب بيانات هرمي.تستطيع الحصول على عناصر البيانات المضمنة داخل عناصر بيانات أخرى لأي عمق تريد.كل عنصر محصور بمجموعة 
من الوسوم»ءفي هذه العينةءالوسوم هي oااعم؛‏ ٥erِthء totalCount world‏ »و oodbyeو.تظھر‏ الوسوم دائما ضمن<أقواس ıڊbracketsã angle‏ > 
ودائما تظهر بشكل زوجي »كما في<٥|اه"/>...<هااه>‏ .(ومن هنا أتت القاعدة"إذا فتحته »أغلقه")لاتنس " / " قبل اسم الوسم في قوس الإغلاق. 

هذا البناء يتح لك تنظيم بياناتك في وحدات مسماة منظمة بشكل خاص.من أجل الوسوم التي ليس لديها شيء بين البداية والنهايةءتستطيع استخدام البناء 
المختزل(المختصر ×ھ† shortened syn‏ ) ></ tagname>»كما‏ فعلت مع الوسم .goodbye‏ 

على فكر ةرمس 6ط ر8ءوسوم 01 ×حساسة لحالة الأحرفه۷آاائممء-مءهم ٬لذلك‏ اكتب بحذر. 


إنها قابلة للقراءة من قبل الإنسانءبفضل جميع الفراغات البيضاءءعلى الرغم من أنك تستطيع إزالة هذه الفراغات وسيبقى لديك N1.‏ ».وهي أيضا قابلة للقراءة 
من قبل الكمبيوتر بسبب الاستخدام الراسخ ١‏ 6اءأومممللوسوم. 


جميع ملفات 01 ×لديها عنصر جذر يا٥‏ ٠/ع ٥۲‏ مفرد والذي يجب أن تظهر فيه جميع العناصر الأخرى. في العينةء<ه|ااه> هو العنصر 
الجذري(الإقلاعي).حالما يتم إغلاق ذلك العنصر(من خلال وسم النهاية له)لاتستطيع إضافة أي عناصر إضافية. 


شاهد السطر <-- .٠ء1‏ aاوك ۴1na11y, re41‏ --! > إنه تعليق.تستطيع لصق التعليقات هنا وكأنها وسوم حرة الحركة وہااھ٥!اf-free‏ 
.tags‏ 


تدعم 01× تنو عينء ما عامج من البيانات:هاهل إهه؟ البيانات الحقيقية والمواصفات.ءهاںطا!)ج.قيم البيانات الحقيقية تأتي بین صلب 5ه |۸٣6۲"‏ زواج 
الوسوم»كما مع.۷1× 11ط¿ و34 . 694 في العينة.توفر المواصفات معلومات موسعة حول الوسوم نفسها.لقد ضمنت مواصفة عأ ں طا٣))ةمسماة‏ 

ا عو ۲ه في العنصر ١اهس.إن‏ المحتوى لجميع المواصفات يجب أن يكون ضمن علامتي اقتباس("").كان باستطاعتي جعل هذه المواصفة عنصر فرعي 
subelement‏ بدلا عن ذلك»والكتیر من الناس يعملون ذلك. یوجد عدم اتفاق 6٣۲‏ ۲۴۵۴۳وهءال‌بين المبرمجين بخصوص متى يجب أن تكون البيانات عنصر 
أو مواصفة دع ضميرك "٥٥‏ ءاعو مء (قلبك )يقودك(يدلك). 


.×١1 )۲ه " التجارية التى ذكرناها سابقا فى‎ W٣١١ دعنا نرى كيف تبدو البيانات المفصولة بفاصلة من قاعدة بيانات "'نورتويند‎ 
E SN aS eo I O 
BESSA ENS > 
<supplier ID="652" ful l1IName="Beverages R Us"> 
<product ID="1" available="Yes"> 
<productName>Chai</productName> 
<category>Beverages</category> 
URI PETES NO. OOSVUR1 EEEICES 
WMDEOSIME E 
</supplier> 
<supplier ID="9874" fullName="We Sell Food"> 
<product ID="2" available="No"> 
<productName>Chang</productName> 
<category>Beverages</category> 
<unitPrice>19.00</unitPrice> 
VBEOQUCE > 
<product ID="3" available="Yes" onSale="true"> 
<productName>Aniseed Syrup</productName> 
<category>Condiments</category> 
MI EEEICGE 12. OOS MRA EEEIGE 
MOEOCSUEE 
</SUpPl1ler > 
KUBESISDEEISE, 


نقل البيانات إلى ا01 ×قد زاد بشكل كبير حجم المحتوى.ولكن مع الزيادة في الحجم تأتي الزيادة في القيمة المعالجة.لقد كان باستطاعتي بشكل مباشر الحصول 
على بعض الفائدة من تركيب 01× الهيكلي .في البيانات الأصليةءالمزود ۲٠ااممںء‏ كان عمود أخر فقطولكن في نسخة 1 ×»جميع البيانات تم تجميعها الآن 
ضمن مقاطع المزودءااممںء ءوالتي تكون مفهومة(على الأقلءإذا ما كانت هذه هي الكيفية التي عملت على تخطيطها لاستخدام البيانات). 

ويمكنك أن ترى أني قد اتبعت القاعدةءكل سمة مفتوحة لديها سمة إغلاق مطابقة.مهما تعمل لاتنس القاعدة. 


الفص التالث عشر:لغة الترميز القابلة للتوسع. Mhm76‏ 
واحدة من الأدوات المستخدمة مع ا١×هي7‏ 51× ءوالتي تحل محل ١s‏ 0اأمصاهsfoمra"‏ تحويلات اS1×‏ ( S1×تحل‏ محل لغة الصفيحة النمطية القابلة 
للت رسع Stylesheet Language‏ eاeXtensib‏ ).إن من الصعب على 81_۲× استخدام لغة الصياغة مومuوہها‏ وام آإمء والتي تتيح لك تحويل بعض 
بيانات ا ×إلى أي نوع بيانات آخر »أو تنسيق مخرجات تريده أنت.فهي مجرد مقدار قليل من اللغات المتعلقة ب 81× المنشئة لمعالجة بيانات ا۸×بطرق 
معقدة.لنرى عمل S1×خذ‏ القطعة المفيدة من 1 ×المجدولة سابقا(العينة >productList>)وبدJ‏ السطر الأول ?xml‏ بالأسطر التالية: 
EMI VeESTORM= I O E>‏ 
ا elle.‏ ا <?xml-stylesheet E E‏ 
SL EEE "2>‏ 
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">‏ 
SN empl ale Ma ECR‏ 
SRS EXE‏ 
ProductID, ProductName, SupplierID, Category, UnitPrice, Available‏ 
xsl EexXE>‏ 
BRS‏ 
<xsl:apply-templates/>‏ 
</xsl:template>‏ 
<xsl:template match="supplier">‏ 
<xsl:variable name="supID" select="@ID"/>‏ 
<xSl?EOE-eacCN SeElECE="BDPEOIUCE >‏ 
SNE Value OE Sele NDS‏ 
<xsl:value-of select="productName"/> ",‏ 
<xsl:value-of select="$supID"/> ","‏ 
<xsl:value-of select="category"/> ","‏ 
<xsl :choose>‏ 
<xSsl when test" Congal e true lL>OnN Sale</x<Sl iwhen>‏ 
<xsl:otherwise>$‏ 
<xsl:value-of select="unitPrice"/>‏ 
</xsl:otherwise>‏ 
N ESSE‏ 
<xsl:value-of select="@available"/> "‏ 
SER‏ 
</xsl: for-each>‏ 
</xsl:template>‏ 
</xsl:stylesheet>‏ 
لقد أخبرتك آنه صعب الاستخدام»وحتی الأصعب النظر إليه.والاآن من أجل العرض.لدي مستکشف انترنت ۲ع oام×X |nternet ٤‏ منصب على نظامي»ولکن هذا 
سيعمل مع غلب المستعرضات الحديثة. افتح ملف ا"×.هاامم في مستعرضك»سيظهر النص المنسق الجميل التالي: 
ProductlD,ProductName,SupplierlD,Category, UnitPrice, Available‏ 
"Chai", "652", "Beverages", " $18.00", "Yes"‏ ,"1" 
"Chang", "9874", "Beverages", " $19.00", "No"‏ ,"2" 
"Aniseed Syrup", "9874", "Condiments", "On Sale", "Yes"‏ ,"3" 
والآن »هذا محبب أكثر »حيث اجتمعت كل من XML‏ 1×مع بعضهما وصنعا هذا التقدم في تقنية البيانات الممكنة.(لقد عملت خدعة صغيرة في هذا 
المثال»ستلاحظ المدخلات</BR>‏ في صيغة 1والتي لاتظهر في المخرجات النهائية.وقد عملت هذا لتبدو مناسبة في مستعرضك)»ولکن بشکل جدي»علی 
الرغم من أنني كنت قادر على توليد مجموعة بيانات مفصولة بفاصلة ء comma-separated daa‏ من خلال 51× فان مھمات أکثر شیوعا ل 1۲؟S×‏ 
تتضمن توليد 1۲1 منسقة بشكل جميل بالاعتماد على بيانات ٠×01‏ أو توليد مستند 11× ذو عرض بديل خاص للبيانات الأصلية.كيف يعمل؟ 
بشكل أساسي» تخبر العناصر <#اوامصها:اء×> المفسر ٣5۲‏ همللبحث عن وسوم في مستند 1× والذي يطابق نموذج(عينة) ما ١6۲ااهم‏ (مثل 
٣ieاممupء).عندما‏ يجد مطابقةءفإنه يقدم كل شيء داخل الوسوم <#اهام"هt:اء×>إلى‏ وسم 11 ×المطابق ومحتوياته.العينة(النموذج)المخصص في المواصفات 
match‏ تستخدم تقنية ا ×تدعىم و :نظام للبحث بشكل عام عن الوسوم المتطابقة ضمن مستند .×١1‏ 
من الظاهر أنه مربك!إهو كذلك. 


تتیح لك × (تعاریف ترکیب 1[ ×› Structure Defi ni†i0 Ns‏ اXM)‏ تعریف مخطط إما "لغۃموھںوہھ| ' أو "'مفرداتراھاںuطھعم‏ ' لمستند 
1 ×خاص بك».تذكر »أن 1 ×معيار شامل مفتوح وواسعءتستطيع تعريف الوسوم بأي طريقة تريد ولن يأبه أحدءعلى الأقل حتى يصبح من الواجب عليك 
معالجة الوسوم ضمن برمجياتك.فإذا لم تكن صحيحة»ءفمن المحتمل أن تفشل معالجتك.تتيح لك 5D×تعريف‏ القواعد التي يجب أن يتبعها مستندك ا ×إذا كان 
يجب اعتباره مستند صحیح من أجل أهدافك. 
(0۲0 تعریف نوع مستندہniti0 Document ype Defi‏ »مشابه لS0×‏ »مع أنه تقنية أقدم. وهو مدعوم بشكل واسع من قبل أدوات 01 ×ءولكنه ليس بتلك 
المرونة التي عليها 5× .يوجد أيضا لغات تعريف مخطط أخرى مشابهة ل 5D×ءولكن‏ بما أن 5D×مبني‏ داخل الدوت نت فإننا سنركز عليه.) 
مخططات 80× هي كل بت مقدر (متمنوہاا هله )كما هو الحال في صيغ 11× .لنعمل على إنشاء ©8×من أجل مثالنا 1× <اوا اا uههءم>‏ الذي 
ذكرناه فيما سبق .أو لاءنحتاج إلى تغيير أعلى ا0 ×لنسمح له معرفة أن ملف 8D×هو‏ المتاح.غير التالي: 

<؟"xml‎ version="1.0؟%>‎ 

<productList> 


إلى: 


<؟"xml‎ version="1.0؟>‎ 


Mhm76 الفص التالث عشر:لغة الترميز القابلة للتوسع.‎ 
"productList xmlns="SimpleProductList> 
"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance 
<""xsi:noNamespaceSchemaLocation="hello.xsd 
هذه التعليمات(التوجيهات وع۷آاء مال )تخبر مفسر ا0 )للبحث في مخطط لء×. اام .وهي تعرف أيضا فضاء أسماءءفيما بعد.يحتوي ملف لء×. اام"‎ 
المخطط التالي:‎ 
"xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema> 
<"targetNamespace="SimpleProductList 
</'""xs:element name="productList" type="ProductListType> 
<"xs:complexType name="ProductListType> 
<xs:sequence> 
"xs:element name="supplier" type="SupplierType> 
</"maxOccurs="unbounded 
<xs:sequence/> 
<xs:complexType/> 
<""xs:complexType name="SupplierType> 
<xs:sequence> 
"xs:element name="product" type="ProductType> 
</"maxOccurs="unbounded 
<xs:sequence/> 
</""xs:attribute name="ID" type="xs:integer> 
</""xs:attribute name="full Name" type="xs:string> 
<xs:complexType/> 
<"xs:complexType name="ProductType> 
<xs:sequence> 
</'""xs:element name="productName" type="xs:string> 
</'""xs:element name="category" type="xs:string> 
</'""xs:element name="unitPrice" type="xs:decimal> 
<xs:sequence/> 
</""xs:attribute name="ID" type="xs:integer> 


</""xs:attribute name="available" type="YesOrNoType> 
</""xs:attribute name="onSale" type="xs:boolean> 
<xs:complexType/> 
<'""xs:simpleType name="YesOrNoType> 
<"xs:restriction base="xs:string> 
</'""xs:enumeration value=" Yes> 
</'""xs:enumeration value="No> 
<xs:restriction/> 
<xs:simpleType/> 
<xs:schema/> 
يبدو أنه متداخل»أليس كذلك؟عمليا إنه أكثر بساطة من 817×.بشكل أساسيءيقول المخطط أنه من أجل كل عنصر(أو "وسموه] " أو "عقدةملمم ")في‎ 
»ونوع البيانات لكل منهم.تستطيع حتى إنشاء آنواع بيانات‎ ج))٣اط‎ u مستندي 1× »هنا تو جد العناصر الفرعية ءأم "هام طنءوالمواصفات التي تحويهاءع|‎ 
مستعارة(أو زائفةعاو لمل ںمءم ) خاصة بك(عملياءالعوامل المقيدة وإماعه؟ وذا "!| على أنواع البيانات المتواجدة)ءكما فعلت مع نوع البيانات‎ 
.١ل0 يقيد القيمة المتعلقة إلى نصوص نعم ءم۷و لا‎ يذلاو»۲es0rN01yمم‎ 
تستطيع النظر إلى ملف »مع مخطط 5D×الملحق(المرافق) في مستعرضك.ولكنه لن يكون بكل تلك الأهمية.إنه يريك فقط ال 1 ×.ولكن المخططات‎ 
ستكون مفيدة عندما تحتاج تقييم(تعيين أهمية) النوعية بالنسبة لبيانات ا0 ×التي تأتي ضمن تطبيقات برمجياتك من مصادر خارجية.‎ 


يمكن أن تختلف قائمة المنتج ازا انال هم ل 01 ×التي عرضتها سابقاءفقد تكون ذات اسم مختلف وقواعد تنسيق مختلفة أيضاءعلى سبيل المثال»يمكن أن يتم 
إنشاء مستند بحيث يبدو كالتالي: 
>؟version="1.0‏ xml"؟<‏ 
<allProducts>‏ 
<"vendor ID="652" vendorName="Beverages R Us>‏ 
<"item ID="1" available="Yes>‏ 
<itemName>Chai</itemName>‏ 
<group>Beverages</group>‏ 
<priceEach>18.00</priceEach>‏ 
<item/>‏ 


الفص التالث عشر:لغة الترميز القابلة للتوسع. Mhm76‏ 
<vendor/>‏ 
<allProducts/>‏ 
جمیع البيانات نفسهاءولكن الوسوم sوه)مختلفة.‏ مستند مٽل هذا سیکون متضارب gaincompatible‏ برمجيات مكتوبة للعمل مع مستندنا الأصلي ,فتشغيل 
المستند من خلال 55×الخاص بنا سوف يخبرنا بسرعة أن لدينا أخطاء في مجمو عة البياناتاعء وأدل واوهط »ولكنه سيكون من الجميل لو أخبرنا شيء ما 
هذا من البداية. أدخل فضاءات الأسماءsعcھesp‏ ”2^ . 
توفر فضاءات الأسماء sععوموءع‏ ”وم طريقة مريحة لقول"هذا الوسم الخصوصي في مستند 01× يستخدم لغة التعريف xSD-defined language‏ 
هذه."لاحظ بداية مخطط 55D×المبين‏ سابقاً: 
"xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema>‏ 
هذا السطر يثبت فضاء الأسماء المسمى و»باستخدام المواصفة وماص»×.(الجزء ء×:يخبر 0_1 ×ماذا تريد أن تسمي فضاء أسماءك.)قيمة المواصفة هي 
معرف(محدد) مورد Uniform Resource Identifier (URI)‏ » مجرد قيمة مفردة ومميزة بحيث تكون واثق من آنه لن يستخدمها شخص أخر. 
نموذجياءتستخدم عنوان موقع ويب من أجل شركتك٬ليس‏ من الواجب أن يكون الموقع موجود.تستطيع حتى وضع رقم هاتفك هناك»مجرد كونها قيمة مفردة 
ومميزة. 
الطريقة الأكثر شيوعاً في استخدام فضاء أسماء هي سبق الوسوم ذات الصلة في مستند 01× باسم فضاء الأسماء الجديد»كما في" ه٣‏ ععء:ء× "عوضاً عن 
schema "‏ "فقط. و هذا يقول للمفسر"إذا كنت تختبر بناءي على مخطط 0D‏ استخدم الاسم الذي حددته لفضاء الأسماءير " تستطیع أيضا استخدام فضاء 
الأسماء "الافتراضي)ااه؟مل " أيضا من أجل عنصر معطى وجميع ما ينحدر منه كأ٣‏ ولم هءءهلبتضمين المواصفة وا" »في عنصر خارجي.ومن ثم 
جميع العناصر ضمن ذلك العنصر الخارجي سيستخدم فضاء الأسماء المخصص.ولقد استخدمت هذه الطريقة في واحد من الأمثلة السابقة: 
<productList xmins="SimpleProductList"...‏ 
من أجل ملفات 01 ×القاعدية والتي سيتم استخدامها فقط بواسطة برنامجك»من المحتمل أن لاتحتاج التعب بفضاءات الأسماء.في الحقيقة تأتي في المتناول 
عندما تعمل على إنشاء بيانات 1× والتي تستخدم معیار توزیع عمومي 2۲ل ھاء ۵٥۸ءاااںم‏ راicااuم‏ نوعا ما.یوجد أیضاً حالات (نسخ) بحیٹ ومن 
المحتمل أن يحتوي ملف 01 ×مفرد بيانات ذات صلة باستخدامات متمايزة لاثنان أو أكثر من 01 ×.في هذه الحالةءالأجزاء المختلفة من ملف 1ا »يمكن أن 
تشیر إلى فضاءات أسماء مختلفةsڄnamespac‏ . 
بالنسبة للأجزاء الأخرى من عالم ×١1‏ » SD×وفضاءات‏ الأسماء ليست سهلة الاستخدام»ولكنها مرنة عاطا×ه|fوقويةاں؟‏ م سهم .وكالعادةءتوجد أدوات 
ءاه أدوات مضمنة في الفيجوال أستوديوءوالتي تتيح لك بناءها جميعا دون أن يكون عليك التفكير بخصوص التفاصيل. 
كما أقول دائماًءإن 11 ×هي مجرد بيانات»ء 01 »وتقنياتها ذات الصلة توفر طريقة للمساعدة في ضمان هوم أن بياناتك جاهزة للاستخدام في تطبيقك. 


تتضمن الفيجوال بيسك طريقتين للعمل مع محتوى_0 × :الطريقة القديمة والطريقة الجديدة.تستخدم الطريقة القديمة فئات من فضاء الأسماءا×." ءاور › 
وتوفر وصول تقليدي معتمد على كائن 4 هءهط-اءهزطمإلى وسوم 01× ءالمواصفات وع | ں طز٣)ج‏ »والبيانات ههل .الطريقة الجديدةءتم تقديمها في 
الإصدار 2008ءتستخدم الفئات في فضاء الأسماء ٩inا.Xn. System‏ و توفر وصول إلى محتوى 1 ×مباشرة ضمن بناء الكود المصدري a‏ 
بيسك.سأناقش كل من الطريقتين في هذا الفصل. 
بما أن جودة إدارة ا ×لیست بقدر ضخامة مقطع نصه»ءتتضمن الدوت نت العديد من الفئات التي تدیر بیانات اM×.جمیع‏ هذه الأدوات تظهر في فضاءِ 
الأسماء اXm. System‏ وفضاءات الأسماء التابعة له: 
System.Xml‏ 

التجميع الرئيسي للفئات ذات الصلة ب 1× في الطريقة القديمةومءءcla old-way XML-related‏ . 

System.Xml!.Linq 
.وهذه هي الطريقة الجديدة والتي سأتحدث عنها لاحقاً.‎ [| N۵ الفئات التي تكامل(تدمج هاه وعا١| ) ا01 ×مع تقنيات لينكو‎ 

System.Xml.Schema 
.×؟S5 الفئات التي تنشئ وتستخدم مخططات‎ 
System.Xml.Serialization 
. standard .NET sreanةيسایقلا الفئات التي تقرأً وتكتب مستندات ا ×بواسطة جدولة دوت نت‎ 
System.XmI.XPath 

الفئات التي تنفذ تقنية ۸ج۴ ×المستخدمة لبحث مستندات .×١11‏ 

System.Xm!.Xsl 
الفئات التي تمكن تحويلات ا؟5×.‎ 
. ×S؟2و‎ ×S817 الميزات المضمنة في كل فئة ترتبط بإحكام إلى تركيب_ 01 ×والتقنيات ذات الصلة مثل‎ 


يتضمن فضاء الأسماء ا×.”هاءرك ه1٠‏ أغلب الفئات القاعدية التي ستستخدمها لإدارة بيانات 1× .إن الكائن امصںء هم٥١"‏ ×هو العرض في الذاكرة 
لمستندك 01 ×الفعلي: 
Dim myData As New System.Xml.XmlDocument‏ 
إن مستندك مركب من التصريحات ء١‏ هااوإهاعمل (ذلك الشيء<7...١×?>‏ في الأعلى)» عناصر البياناتوام" ءام وهل (جميع الوسوم ووهإالنوعية 
في مستندك))المواصفات ء٥‏ ںطا۲))ج ( داخل كل بداية وسم عنصر)»والتعلیقات‌ یا6" "٥ء‏ .وهذا كله يتم تمثيله بواسطة الفئlٽ «XmlDeclaration‏ 
Attribute‘XmlElementاXm‏ » 0mmentع|اm×على‏ الترتيب.مع بعضها هذه الوحدات الأربع لمستندك تدعى "العقد وممم” "ءممثلة بشكل عام بواسطة 
الفئة .(جميع الفئات الأربع ترث من الفئة القاعدية ملهل١ا×‏ الأكبر).عندما تبني مستند 1 »يدوي في الذاكرةءفإنك تستخدم فئات مستقلة مثل 
ementاEاX×m.بعدئذٍ»‏ عندما تحتاج لعمل مسح خلال مستند موجود»من الأسهل استخدام الفئة مله١ا×الشاملة.‏ 
دعنا نبني مجموعة جزئية من مثال بيانات اnlنتج XML product data‏ . 
Kazxml versio I O‏ 
EBEOGUE EL SE‏ 
We currently sell these items. =->‏ --!< 


الفص الثالث عشر:لغة الترميز القابلة للتوسع. 


إنه يعمل حقاءلبرهان ذلكءضع هذا الكود في حدث النقر لزر ماءوأنهيه بالسطر التالي(أي أضف السطر التالي لنهاية الكود السابق). 


شغل البرنامج واعرض الملف /”× e‏ :علرؤية product daa‏ اM×.توجد‏ عدة طرق مختلفة لاستخدام فئات 01 ×لإنشاء مستند ا0 ×في 


الذاكرة. على سبيل المثال»على الرغم من اني استخدمت الطريقة ماںطا٣))‏ ه5 لإضافة مواصفات إلى عقدة المزود ysupplier‏ inllتproductg‏ ءفقد أستطيع 
إنشاء كائنات مواصفات منفصلة»وتزيلهم على هذه العقد٬تماما‏ مثلما فعلت من أجل العنصر الرئیسی 


إذاء هذا جميل »ولكن ماذا بخصوص إذا ما كان لديك بعض ا0 ×في ملف ماءوتريد تحميلها في كائن ٤٣م‏ uءه٥|"×؟ببساطة‏ استخدم الطريقة لهه ] للكائن 
.XmlDocument‏ 


ال الات ف ار ا ال Mhm76‏ 

من أجل تلك النسخ(الحالات)التي تريد فقط القراءة أو كتابة بعض 1ا »من أو إلى ملف ماءولا تأبه كثيرآ بخصوص معالجتها في الذاكرةءتتيح لك الفئة 
|r extReader‏ m×و‏ الفنُة |r extW rier‏ m×قراءة‏ وكتابة بيانات 01 ×بسر عة بواسطة جدولة النص" 4٠١1ء‏ ×ه] .ولكن إذا كنت ذاهب لعمل أشياء ببيانات 
× في برنامجك»فإن الطرق 4ههار مه8 لكائن etصuعمطاص×هي‏ الخيار الأفضل. 


في مثال البیانات خاصتناءجمیع المنتجات واcں‏ لہ متظھر في مجموعات المزود.إذا کنا نرید فقط قائمة بالمنتجات ءا uں‏ لهم »بغض النظر عن المزود 
ierاsupp»نطلب‏ من الکائن e٤‏ صں‌م ۱٥‏ ×تزويد تلك البيانات بواسطة الكائن ءز1 ملN0|"×.‏ 
Dim justProducts As XmlNodeLlList‏ 
Dim oneProduct As XmlNode‏ 
EMESE, Gel Ehe LISE.‏ آ١‏ 
jJustProducts = products.GetElementsByTagName ("product")‏ 
Then do something with them.‏ جک ٣‏ 
EOE Hacl OReELOIUCE IN JUSEEEOAUCES‏ 
Put interesting code here.‏ کے ل 
Next oneProduct‏ 
MEE Eo (HY EEOC FF € USL EEOCUCES . COURE HONEY & FF Seocuekt (SN‏ 
من أجل اختيار أكثر تعقيدا للعقد ضمن المستندءينفذ فضاء الأسماء 1ة۴×.١×."هاوءرك‏ لغة بحث ۴۸× ءوالتي تمنحك مرونة زائدة في البنود المستكشفة. 
تصف مجمو عة مستندات الفيجوال أستوديو بناء الطرق والبحث المستخدم مع هذه الفئات. 


يستطيع الكائن ٣مصںءم0|ص×الاحتفاظ‏ بأي نوع من محتوى _0×المحقق والعشوائي»ولكن تستطيع أيضا التحقق من المستند على مخطط 50×.إذا كان 
مستندك 1 »یشیر إلى مخطط 55× »أو يتضمن ٥0۲0ء‏ أو يستخدم 5۸ل(مخططات بيانات Data Reduced schemas ةlزتخمل|X ML‏ اe×Mمشابھa‏ 
لX×SD‏ )ءأو Reader‏ m×»ءعند‏ تركيبه بو اسطة إعدادات قارئ ءو”ا۲56مكه٠‏ ۸× مناسب»سيقارن بدقة بيانات ا ×على القواعد المعرفةءويرمي باستثناء 
إذا كانت هناك مشكلة. 
Dim products As New XmlDocument‏ 
Dim xmlRead As XmlTextReader‏ 
Dim withVerify As New XmlReaderSettings‏ 
Dim xmlReadGood As XmlReader‏ 
Open the XML file and process schemas‏ ص ل 
referenced within the content.‏ ' 
withVerify.ValidationType = ValidationType. Schema‏ 
xml1Read = New XmlTextReader ("c:\temp\products. xml")‏ 
xmlLlReadGood = XmlReader.Create (xmlRead, withVerify)‏ 
Load content, or throw exception on‏ خت ل 
vali dat FOn Ea lUEe.‏ 5 
products. Load (xmlReadGood)‏ 
Clean up.‏ ا 
xmlLReadGood. Close ()‏ 
xmlRead. Close ()‏ 


تحويلات ا5×ليست أكثر صعوبة من أية معالجات أخرى ل01 × .كما يوجد العديد من الطرق للحصول على بيانات مصدرية ل ا×(من ملف»بناءه بشكل 
يدوي بو اسطةا ٥‏ ںءه ×۱٥‏ » إلخ)ءيوجد أيضا عدة طرق لتحویل البیانات.إذا كنت ترید فقط التنقل من ملف مدخلات ٥اا‏ اام¡ إلى ملف مخرجات 
ها utputد»‏ فإن الكود التالي يوفر طريقة فعالة وسريعة. إنه يستخدم حالة Transform‏ Xs|.XsICompiled.اsystem.Xmلإتمام‏ العمل. 
Above: Imports System.Xml.Xsl‏ س ص ل 
Dim xslIGanSs AS XSICOMPIlEeAREANS EOEM‏ 
Open the XSL file as a transformation.‏ کد ا 
xslTrans = New XslCompiledTransform()‏ 
xSNTEaAN SL LOA UES NEORNETE <S)‏ 
Convert and save the output.‏ جص ا 
SSE EAN SEAR SE SEMO ES DBE EMU, TE. \ODEPUE ESE)‏ 


عندما ظهرت الفيجوال بيسك للمرة الأولىءلم يكن أحد قد سمع ب 1 ×.ولكن الآن إنها في كل مكان.والآن في الفيجوال بيسك2008 أصبحت جزء من بناء 
اللغة نفسها.أين سينتهي بها المطاف؟ 
إن إخراج(إزالة) ما يجعل ۷N]‏ ×جزء من اللغة بعيد نو عا ما في مقطع الطريقة القديمة »أريتك بعض الكود الذي ينشئ N1‏ لقائمة المنتج product list‏ منj‏ 
أجل "وط٣‏ " محتوى × كان بطول 1 1سطر »ولكنه يأخذ تقريبا 50 سطر من الكود المصدري لإنتاجه.ولكن تستطيع بناء نفس محتوى 01× باستخدام 
الطريقة الجديدة بحوالي 11 سطر تقريباً. 
Dim chailtem As System.Xml.Linq.XDocument = <?xml version="1.0"?>‏ 
EOE EELS E‏ 
We currently sell these items. =->‏ --!< 
<supplier ID="652" ful lName="Beverages R Us">‏ 
<product ID="1" available="Yes">‏ 


الفص التالث عشر:لغة الترميز القابلة للتوسع. Mhm76‏ 
<productName>Chai</productName>‏ 
<category>Beverages</category>‏ 
<unitPrice>18.00</unitPrice>‏ 
BECOMES‏ 
</supplier>‏ 
VBEOSUEE SES‏ 
ما عدا سطر التصريح الأول.المحتوى مطابق ل 01× النهائي.إن ميزة 1 الحر فية الجديدة ۵إ ںام s/۾rع٤/L‏ 01× سهم تجعل بناء مستندات ×XML_‏ 
موجز ومحکم.یتم تخزین المحتوی في کائن e٣٤‏ صںء‌ه0×جدید» جزء من فضاء الأسماءوہ1ا.۱×.٣‏ ۵ور .إذا ردت تخزين فقط مقطع 01 ×بدلا من كامل 
المستند»استخدم الفة ٤٣٥صها۴×بدلا‏ عن ذلك. 
Dn OEOCUCESOCELON AS SNES SM, LLOE. SLE = |‏ 
<PEOQdUCE ID" availlable="yesls‏ 
<productName>Chai</productName>‏ 
<category>Beverages</category>‏ 
SUNTEBELCE IG OOS EEE GEZ‏ 
MBE OSU‏ 
إذا کتبت تمکین الاستنتاج(الاستدلال) في برنامجك(خیار الاستنتاج فعالہ 0 Option Infer‏ )»فلا تحتاج حتى لإخبار الفيجوال بيسك فما إذا کان gİÎXElement‏ 
.XDocument‏ 


Dum OEOCUMECEIECEIOS = _| 
<product ID="1" available="Yes"> 
<productName>Chai</productName> 
<category>Beverages</category> 
SUNI EEBEIECEZN SG OOS UNM EBE Gez 
CC ASEONOE 


فبمجرد تشابھھ مع فة ا 0une‏ |"×ءتتضمن الفنةَ ٤ہ‏ مصںء00×الطرق "تحميل لوه "و "حفظ م۷ه5 " لإدارة ملف معتمد على .×١1‏ 


تضمين ا ×في كودك المصدري مادة مدهشة»ءولكن ستبقى مدهشة لو اشتريت دائما "الشاي اها " ب " $18.00"لكل وحدة فقط.محتوى 0_1 ×الحقيقي 
يأتي عادة من بيانات متغيرة.وعلى الرغم من أن 1 ×اسم "حرفي |هء6]أ] "ءيمكن لحرفيات XMLن‏ تتضمن محتوی غير حرفي من خلال تعابیر ا0/1 × 
المدمجة ed ×۷1 e×مrِess/ 0۸s‏ عط e”‏ .حيثما تريد إلى إضافة بيانات من متغير أو تعبير لنص »تستخدم الرموز =%>و<# لتعويض بياناتك 
Dim PEOGUEENaMe AS SEEING CEMAT‏ 
Dim productCategory As String = "Beverage"‏ 
Dim productPrice As Decimal = 18@‏ 
Dim isAvailable As Boolean = True‏ 
DI OEOCUEC ESOCELOR = |‏ 
<BEOQUCE ID <S PEOCUCLID >‏ 
available=<%= Eormat (isAvailable, "Yes/No") S>>‏ 
<productName><%= productName %></productName>‏ 
<category><%= productCategory %></category>‏ 
<unitPrice><%= productPrice %></unitPrice>‏ 
MBEOMIEOE‏ 
بالطبع »من أجل إنتاج تصنيف المنتجات ءأعں لمم كامل»سيكون عليك عمل الكثير من الكتابة.في الفصل 17ءسأقدم بعض الطرق الإضافية لتضمين تعابير 
ا ×مع کامل جداول البیانات. 


سابقا في هذا الفصل» في مقطع "إيجاد الإبر وكومات القشء)عهاءره! كه sمالممN‏ وinه۴in‏ "ءبينت لك كيفية الوصول إلى مقاطع نوعية لمستندات 
XM‏ القديمة النمط.تتضمن كائنات 11× الحديثة النمط أيضا طرق لعمل مسح والوصول إلى أقسام 01 ×الشجرية. 
وهذه تدعى الخاصيات المحورية ذ1× »وهي تأتي محزمة في ثلاث تنوعات بنائية محببة: 
محور العضو Child-member axis j|‏ 
تستطيع الوصول إلى وسم فرعي(ابن)مباشرةٌ لأي ٣٠٣۲‏ ٠|ع×باستخدام‏ اسم الابن كعضو لكائن الأب ٬تغليف‏ اسم الفرع في مجموعة أقواس محدبة: 
childElement = parentElement.<childName>‏ 
محور العضو اia>در Descendent-membe/ axis‏ 
تنوع عن بناء محور العضو الابن يتيح لك الوصول إلى الأعضاء المسماة عند أي عمق ضمن عنصر الأب. بدلا من استخدام فقط نقطة مفردة.) بين أسماء 
الأب والابن»استخدم ثلاث نقاطل.): 
setOfElements = parentElement...<descendentName>‏ 
محور المواصة. Attribute axis‏ 
الوصول لأي مواصفة لعنصر بمعاملة اسم المواصفة كاسم عضو»اسبق اسم المواصفة بالرمز @ . 
attributeValue = parentElement.CGattributeName‏ 
المقطع التالي من الكود يعمل مسح على قائمة المنتج الذي صممناه سابقا في الفصل»يعرض رقم المعرف (إواسم كل منتج على لوحة مإمومم . 


BSH Hacl OMEETOAUCE IM ALLBEOIUCES 1. 1 PEOIUCES 


الفص الثالث عشر:لغة الترميز القابلة للتوسع. Mhm76‏ 
COMECLE UE LE LTTE (ORSE E OCUEE OLD GCG NCE |‏ 
oneProduct. <productName>.Value)‏ 
Next OneProduct‏ 
یستخدم هذا الكود ثلاث آنماط محوريةوم‌اراو كز»×ه .تعمل الحلقة Each...Next‏ waForج‏ على مدخلات <اعr0duم>المتطابقة‏ باستخدام محور العضو المنحدر 
axis‏ member-descendent»ءفي‏ کل عنصر منتج متطابقءیصل الکود مواصفة (D|باستخدام‏ محور المواصفةءز×ص attribute‏ »و یحصل علی اسم المنتج 
باستخدام محور العضو الابن‌ءا×ھ ٣مbصہعہ-لااc۸‏ »علی طول مع خاصية القيمة ىں 1ه لعنصر الابن المعادة,تبدو المخرجات كالتالي: 
Chai‏ :1 
Chang‏ :2 
Aniseed Syrup‏ :3 


کما مع الطريقة القديمة في إدارة XM‏ تسح لك الطريقة الحديثة تضمين فضاءات أسماء في محتوی .×M1‏ لإضافة سابقة فضاءِ XMLsla)‏ »ببساطة ضمنه 
في المحتوى كما تعمل مع أي سیناریو أخر. 
Dm fOCOTEEMS |‏ 
SOX VeEESIAON N O‏ 
<menu:items xmlns:menu="http://www.timaki.com/menu">‏ 
<menu : item>‏ 
<menu:name>Pizza</menu:name>‏ 
<menu:price>12.99</menu:price>‏ 
</menu : item>‏ 
<menu : item>‏ 
<menu:name>Breadsticks</menu :name>‏ 
<menu:price>1.99</menu:price>‏ 
</menu : item>‏ 
</menu:items>‏ 


تستطيع أيضا تعريف فضاء الأسماءء الجز ءءما× ءباستخدام تباين(تنو ع" 0ااه ج۷ ) عبارة الفيجوال بيسڭ امم | . 
Imports <xmlns :menu="http://www.timaki.com/menu">‏ 
later...‏ . 
Di EOOCIEEMS = |‏ 
Xml vere loOmR IO‏ 
<menu: items>‏ 
amd SO OM.‏ 
ستحافظ الفيجوال بيسك على إدراج تعريف ,| »في المكان المناسب في محتوى 01× .یتم تخزینه عمل ککûlئj‏ aXNamespaceتjın‏ ضja XDocument‏ 
أو Element‏ X.لإنتاج‏ كائن ءعaمsە Na"‏ ×ما لاستخدامك الخاص»ءتتضمن الفيجوال بيسك الوظيفة (الدالة) معةمsم N2"‏ |" ×اهعالجديدة . 
Dim justTheNamespace = GetXxmlNamespace (menu)‏ 


يريد مدير نظام المكتبة رؤية الإحصائيات والمعلومات بلمحة سريعةءأو تشغيل التقارير المتنوعة التي توفر ملخص هام أو عرض تفاصيل بيانات النظام, على 
الرغم من أنني وكمبرمج أستطيع تجريب إضافة كل نوع محتمل الحدوث ماطج۷أمعمهعمن التقارير التي يحتاجها المستخدمءفقد تعلمت من خبرتي أن هذا 
غیر ممکن.فدائما یرید المستخدم القمر (الزبدة)ءعادة في نموذج مقتصر على تقرير والذي وعلى حد علمي سيتم استخدامه مرة واحدة وبعدها لن ينظر إليه مره 
أخرى. إني لا أحب إعادة تجميع وتحرير كامل التطبيق كلما أراد مستخدم تقرير جديد.بدلا عن ذلك»إني احفظ التقارير خارج نطاق التطبيق»أخزنها كبر امج 
منفصلة . ومن تم»من نموذج واحد في التطبيق الرئيسي»أجعل جميع هذه التقارير الخارجية متاحة في قائمة مناسبة مريحة. 
لتنفيذ هذه الميزة الشاملة ءامنتخدم ملت تر کي تفرير + ملف اڄ×بسیط يحتوي على معلومات عن التقارير المتاحة»وكيفية تشغيلها,أريد قائمة الاختيار الخاصة 
بي أن تتضمن بنود فارغة بحيث أستطيع تجميع التقارير بشكل مرئي وبوسائل مريحة. 
لعمل هذا »سأعمل ملف 1ا »×ضمن تسلسل هرمي بعمق غير محدد»مع تمثيل كل مستوى بأبعد مستوى من الفراغ ٤هل‏ ”| المعروض. على سبيل المثالءلنقول 
أنني أريد الخطوط الرئيسية التالية من التقارير(مع عناوين مجموعة التقرير بخط غامق). 
تقارير التفاصيلs Detail Report‏ 
التقارير llيوميReport Daily‏ 
التقارير اlشرڍReports Monthly‏ 
القيم الشھريãةValue Monthly‏ 
الجرد الٹشهري Monthly Inventory‏ 
تقارير الإيجlز)lاlتنlخيفص(Reports Summary‏ 
ملخښص اجر دmary Inventory Sum‏ 
إعداد 01× سيتبع التركيب التالي: 
<Group name="Detail Reports">‏ 
<Item name="Daily Report"/>‏ 
<Group name="Monthly Reports">‏ 
<Item name="Monthly Value"/>‏ 
<Item name="Monthly Inventory"/>‏ 
</Group>‏ 
</Group>‏ 
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الفص التالث عشر:لغة الترميز القابلة للتوسع. Mhm76‏ 
<Group name="SummaryReports">‏ 
<Item name="Inventory Summary"/>‏ 
CGE‏ 
بالطبع هذا 1× بسیط جداً آ(بغض النظر عن كونه غير ORG‏ )بالإضافة إلى الهرميةءأريد أيضا تضمين دعم لطرق التقرير المتنوعة. لحفظ 
الأشياء بسيطة» 


يتضمن التطبيق عدد محدد من التقارير التي تبنی بشکل دائم في التطبيق الرئيسي(المجمعراا"هءءص ).تم ترقیم التقارير بدءاً من 1»وعند هذه المرحلة لدي 
O TTT‏ ا×تضمينها في عرض التقارير أو لاء بكل بساطة بتضمينها أو عدم تضمينها في الملف.في حال 
غياب ٠١‏ هءطهملف الإعداد» ستظهر هذه التقارير في القائمة بشكل افتراضي.بالإضافة إلى عدد التقارير (من 1 إلى5)ءكل مدخلة لديها نص عرض 

. long descriptionJڍوطؤطÛ‎ dصggdisplay‎ text 


ا 
% 


تكون هذه التقارير ملفات تنفيذية ٤×عمتميزة‏ ومفصولةءوتبدأً بواسطة طرق تمهيد ۸٥اهزامزالتطبيق‏ القياسية.كل مدخلة تتضمن نص العرض رهامءاك 
)×ه)ءالمسار الكامل للتطبيق»ءمعاملات نسبية اختياريةءعلامة لتمرير هویة المستخدم rموں‏ ٥ط‏ ؟ه رانا ملا التي تمهد(تسند قيمة د قيمة ولیت رربو 2 طویل. 


هذه التقارير هي استدعاء بسيط لصفحات ویب أو أي معرف انترنت 81ل .كل مدخلة تتضمن نص العرض»معرف الانترنت R1‏ لنفسه»ووصف طويل. 
ا ی ا ا 


ار هة تضرف فوتیق و اظح على تر کیب وات 0 ا کوج طروة مله لوص تر کیب فا ا إلى مستخدم اعتيادي»على الرغم من أن متل هذا 
التوثيق مطلوب»على أمل أن يتضمن التطبيق أيضا أداة تتيح للمدير بناء ملف التركيب(الإعداد). 


يمكن أن يتم إعداد تطبيق المكتبة ليشغل أي عدد من التقارير من خلال نموذج التقارير .يتم إدارة قائمة التقارير المتاحة من خلال ملف تركيب تقرير ا١×.‏ 
يحتوي الملف "مجموعات ومره۲و " و"بنودو "6| ".جميع البنود هي تقارير»وتظهر ضمن مجموعة,تستطيع إدخال مجموعة ضمن مجموعة أخرى لأي 
عمق »رقا التقارير المعروضة فى برقامج المكتبة مرك فراع لكل محر عة تاعا ار ية لاع الصتم على رزية تلظ التتار یر لایوج خد فال 
المجموعات. 

العنصر الجذري لملف »يجب أن يتم تسميته<اءا امم > «ويمكن أن يحتوي على أي عدد مj‏ eناصر‏ lallنٽ>reportGroup<‏ و :<reportltem>‏ 

) sub 0۲di ١جاهةيوناث(ةعبات مدخلة تقرير مفرد.و هذه المدخلة لديها مواصفة عا ںطا٣)†ج واحدة مطلوبة »وتصل إلى خمسة عناصر بيانات‎ لثمي:>rهpمrاااء‎ n< 


نوع ممرا (المواصفةعا u‏ طم ااج ):تعمل الإعداد إلى راحد من آ5 : 

.جاهز(مبني داخلیاً) ہا۔٤اںط:تشغيل‏ واحد من البرامج الجاهزة(المبنية داخليا). هذا النوع من التقارير يستخدم عناصر البيانات <أ×ه۲رهامءال>» 
<description> ys <reportPath>‏ . 

.برنامجصهء وهم :تشغيل برنامج تنفيذي ۴× منفصل .هذا النوع من التقارير يستخدم عناصر llلبيlنlٽ>ڼdisplay1ex< <reportArgs>« <reportPath>«‏ 
<description> sy‘ <reportFlags>‘‏ . 

.معرف ویباں :يشغل 1ل (محدد مواضع المو ار د المر>ڌد Uniform Resource Locator‏ ) مثل صفحة ویب أو 'برتوکول البریدہ)ازھم " ایمیل 
إلى عنوان مستقبل. هذا النوع من التقارير يستخدم عناصر llلبيlنٽ>ex .<description> s <reportPath>« <displayT‏ 

_ عرض نص<|×٠٣رهامءأك>‏ :اسم مختص أو وصف لهذا التقرير »كما سيظهر في قائمة خيارات التقرير. هذا العنصر مطلوب لجميع أنواع التقارير. 
مسار التقریر <۸ ۲۲۴م مهء> :المسار الكامل اهم اان؟ »محدد مواضع الموارد الموحداR1ل‏ »أو عدد التقاریر ٤مم‏ ٥م number of t۸٥‏ «بالاعتماد على 
نوع التقرير .من أجل تقارير برنامج(تنفيذي ۴× )»هذا هو المسار ٥ل‏ لاالكامل أو مسار المعتمد على حرف السواقة للتقريرءبدون معاملات نسبية إضافية.من 
أجل التقارير الجاهزة(المبنية داخلياہا- اط )هذا هو رقم التقريرءمن 1إلى 5( القيم ومعانيها تم جدولتها فيما بعد في هذا الفصل).من أجل تقارير 1 »هذا هو 
محدد المواضع الفعلي»كما في ×20 0/1 ho /mysite. c0 // 77۲e‏ “أو ”.ite.comئ0:he/pdesk@my‏ ص “.وهذا العنصر مطلوب من أجل جمیع 


معاملات التقریر <وو۲۲۸۲همهء> :من أجل تقارير برنامج (تنفيذي٤×ع‏ )»هذه المدخلة أي معاملات نسبية وا٣‏ عص ںو ولسطر أمر ne‏ ااك com n2‏ يمكن 
تضمينه عند تشغيل البرنامج. هذا العنصر محقق فقط في تقارير البرنامج(التنفيذي)»وهو دائما اختياري. 
إشعارات التقرير <ووه!۲۲۴همه>:من أجل تقارير برنامج(تنفيذي ×٤‏ )»هذه المدخلة هي الدلالات الاختيارية التي يجب إلحاقها إلى أمر التطبيق كمعاملات 
نسبية. عند هذه المرحلة الإشعار الوحيد هو ل.عندما يتم وضع هذا العنصر إلى لءیتم إلحاق المعامل النسبي )میں ں۔ إلى نص الأمر(حيث userid‏ هو معرف 
تسجیل دخول المستخدم من حقل قاعدة البيانات n‏ !اوها UserName.‏ (. هذا العنصر متاح فقط في تقاریر البرنامج التنفيذيع×ع »وهو دائما اختياري 

الوصف <0 ام‌ااموهل> :هذا هو الأطول»وصف كثير الحشو م5٥‏ ط٥رللتقرير‏ »يصل إلى 200حرف»والتي ستظهر على نموذج التقرير Report ٥۲٣١‏ 
عندما يختار المستخدم قائمة نموذج التقرير. سيساعد هذا الشرح المستخدم في اختيار التقرير المناسب. هذا العنصر متاح لجميع أنواع التقارير ءولكن دائما 
اختياري. 

. مجمو عة التقرير <مںهإ۲۲6ممه>:تمثل مجمو عة التصنيف مهال ۷اه وهاه »تستخدم للمجموعة المرئية وترك فراغ في بداية ٤ههم|‏ التقارير في قائمة 
العرض.يجب أن يحتوي هذا العنصر بالضبط العنصر <ا×ه۲رهامءال> الوحيد »ولكن يمكن أن يحتوي أي عدد من الaناصر <reportltem>‏ )و <reportGroup>‏ 
س <ا×٠‏ ۲رهامءزل>نص العرض :اسم مختصر أو وصف لهذه المجموعةءكما ستظهر في قائمة اختيار تقرير. هذا العنصر مطلوب. 
عند استخدام نوع التقرير"الجاهز" يتم وضع العنصر إلى واحد من قيم الانتغر التالية: 

ltems Checked Out Report. دgiبll تقرير مخرجات(مراجعة(‎ 1. 
Items Overdue Report.دgiبl‎ تارخİتn‎ رıرقت‎ 2. 
Items Missing Report.دgiڊ‎ jlدقف تقرير‎ 3. 


الفص الثالث عشر:لغة الترميز القابلة للتوسع. Mhm76‏ 
مستحقات الغرامات بواسbؤطة‏ تقرıر‏ jllڊlئReport.j Fines Owed by Patrons‏ 

Library Database Statistics Report .aڊتüكnئll تقرير إحصاءات قاعدة بيانات‎ 5. 

هذا الوصف التقني يظهر في مستند مجموعة المصدر التقنيءتم تطويره أصلا في الفصل الرابع. 


مع إمکكانيات الدوت نت لتخزين جمیع الكائنات کبنود صندوق تlئnمةms ListBox ite‏ »نستطيع إنشاء فئة خاصة بحیث تحتوي جمیع المعلومات المطلوبة لاختیار 
وتشغيل تقریر من قائمة التقارير. هذه الفئة بسيطة جداًء لایو جد فیها شيءِ ماعدا حقول عامة أساسيةءزائد إعادة قيادة لدالة " "trin‏ والمستخدمة بواسطة 
أداة صندوق القائمة لعرض كل بند قائمة بشكل مناسب. 
في مشرو ع المكتبة»أضف ملف فئة جديدة وسمه ط۷. "۳ء †اأامممR‏ من خلال مشرو ع أءعزهإ۴>> إضافة فنةووهاح ل١ك۸‏ .ومن ثم أضف العداد التالي لهذا 
الملف»ولكن أضفه خار ج الحدود ووا ١"s...6ءها٤.‏ يشير هذا العداد إلى ما يمثله نوع مدخلة كل بند قائمة.كما يلي: 

BPUBDIlIE Class REDO EL tem 


End Class 
Public Enum ReportItemEnum 
"نوع بند في قائمة اختيار تقرير‎ 
GroupLabel = 0 
BuiltInCheckedOut = 1 
BuiltInOverdue = 2 
BuiltInMissing > 83 
BuiltInFinesOwed = 4 
BuilléInSstali SE1@€S >= © 
ExeProgram = 6 
WE LErogr am 2 
End Enum 
configuration أضف ئ نفس الملف أعضاء الفئة Reportltem.تحتوي هذه الفئة جمیع المعلومات التي نحتاجها لتشغيل التقارير المحملة من ملف التركيب‎ 
.file 
CEE GG NN CS E E 
RepOELSeleGE 
Public ItemType As ReportItemEnum 
"مستوى الفراغ يبدا بصفر‎ 
Public Indent As Integer 
Buble Dısplavylexst AS SETTING 
EUDIAES RePOrEEFAEN AS SEEING 1 ExePrOGEaM / UELErFOIEAM ORLY 
Publis REDOFEAEIS AS SErINO _1 ExeRrogran Only 
Buble Deser IPE ON AS SETTING 
EuoDlIE Overrides HURGEION TOSSES O AS SEEING 
' .بفراغ مسبوق نص عرض‎ 
REE Ug SE Doel IMEEME < 3, 1 U & DISE E 
ERG HUNGER OR 


یستخدم أمناء المكتبة ٣s‏ هاا ة۲ طا والمدراء gaiadministratorsذج‏ اختیار تقریر(شاهد الشكل التالي) لعرض التقارير .يتضمن النموذج أداة صندوق قائمة 
×180ءi‏ اتعرض جميع التقارير ومجموعات التقارير »زر التشغيل ۸ں # الذي يشغل التقرير »وزر الإغلاق الذي يعود بالمستخدم إلى النموذج الرئيسي.تعرض 
أداة عنونة امطج| وصف كامل عن التقرير»عندما يكون متاح» تحت صندوق القائمة تماماً. 


التقادير 
#llReports‏ 


لإضافة هذا النموذج إلى مشروعك(راجع مشروع هذا الفصل). 
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قن الت فر هة ارم ااا ات Mhm76‏ 

على الرغم من أن المدير عمل على منح أسماء مفيدة لكل تقرير »الاسم المختصر لاسم كل تقرير من المحتمل أنه مايزال غامض بالنسبة للمستخدم.يتضمن كل 
تقریر وصف کامل اختياري. عندما یختار المستخدم قائمة نموذج التقارير »يعمل معالج حدث على تحديث اللافتة FullDescription " label‏ "التي تحت القائمة 
فام ات مال الكت ها 


Dim 


تحمل الطريقة امم ه۸ ۸ءهء؟مRالبيانات‏ من ملف تركيب التقرير وتعالج النتائج.في النهايةءسيتم تسجيل موقع هذا الملف في ملف التركيب للتطبيقءولكن لن 
نعمل على إضافته حتى فصل لاحق. 

أما الآنءدعنا ندخل موقع ملف الاختبار »ونعلمه من أجل التحديث اللاحق.فضلت اختيار كائنات ا0 ×للنمط القديم من أجل هذا الكود لأن ميزات ا0 ×للنمط 
الجديد التي نحتاجها لجعل الكود سهل الكتابة لن يتم تقديمها حتى فصل لاحق. 


Then 


New 


End Ef 


To. CIRE 


New 
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الفص الثالث عشر:لغة الترميز القابلة للتوسع. Mhm76‏ 


ERG SUBS 
لأن ملف تركيب التقرير يسمح بتداخل مجموعات التقرير لأي مستوىءنحتاج إلى استخدام روتين دوري هاو هءللنزول إلى كل مستوى متتابع(متتالي)‎ 
مره بعد مرة.يتم استدعاء الروتين مںه ۲۲6م م٠48 هه ابو اسطة الروتين ءا اهمه ۸RءمRefr »ويضيف جميع بنود التقارير ومجموعات التقارير ضمن‎ 
مجمو عة بدء التقرير .يتم استدعاءه بشكل أولي(مںه 0۲۲6م 40۸6٠1ا) من نقطة مرجعية للعنصر الجذر ي <اءا)۲ممهء> .كل مرة يعمل على إيجاد العنصر‎ 
.<reportGroup>jبٹل| الابن<مںه۲۲6ممهم>ءيستدعي نفسه مره أخرى ولكن هذه المرة يبدأ من نقطة مر جعية "0م 6٥٠۵ع للعنصر‎ 
ByVal 5 ByVal AS EREEIEE 


Dur 
OR EFO GE 


EOE Each Tn 


New 


imo) Mem CONC 


Then 


Then 


TS NOE 


And 


ıt 1nüe 


Then Continue 


14 


الفص الثالث عشر:لغة الترميز القابلة للتوسع. Mhm76‏ 


اعمل على إضافة حدث تحميل ص1 الفورم»والذي يحمل في محتوى الفورم ملف التركيب. 


ject, ByVal As Handles Me 


والآن »هذه جمیع المجموعات والتقارير التي تظهر في القائمة»علينا تشغيل التقارير الفعلية.معالج حدث زر 'تشغیل ہuں‌R|ا٥A‏ " يعالج هذه المهمة.حالياً سنعمل 
على إضافة فقط إطار العمل لدعم الاستدعاء بالنسبة لكل تقرير.أما تقارير "المبنية داخليا ٣اا‏ اط (الجاهزة)"سيتم إضافتها في الفصل21. 
ByVal As Ol ByVal As Handles‏ ) 


4 


Dim 
On EF GoTo 
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الس اللالت حشر هة رمي اانا اتوس Mhm76‏ 
من أجل التقارير الخارجيةءيستدعي معالج الحدث الطريقةاه5.وءهء٠۴۲‏ .وهي طريقة مدهشة تقبل إما تعبير سطر أمر قياسي»أو عنوان انترنت الل 


محقق»أو عنوان صفحة ويب 


لجعل التقارير متاحة بالنسبة للمستخدم»يجب علينا تمكين وصلة لنموذج التقرير من الفورم الرئيسي.فيما سبق عملنا على تضمين لوحة متميزة على تلك الفورم 
من أجل طباعة التقارير فقط. الزر "عمل llتقlرڍر ActDoReports‏ 'غلے تلك الفورم يعمل على إطلاق استدعاء هذا النموذج.انشئ معالج حدٿ جدید للزر" عمل 
التقاریر sا0rممR A00‏ " وآضف الکود. 


EriIvate SUD ACLDOREDOE ES ClTERKEVVaN Sender AS OBJE, BvVal € AS SYSEOM EVUENEREIS) HSI les 
ActDoReports.Click 


ReportSelect.ShowDialog () 
EN SUD 


والآنءلدينا فهم راسخ(عميق)لعالم 01 ×ءسندع الفيجوال بيسك تعمل كل أعمال معالجة العمل الصعب من أجل عمليات إعداد التطبيق. 
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